设为首页 收藏本站
查看: 953|回复: 0

[经验分享] (转载)一些微软 google IBM 笔试题 面试题

[复制链接]

尚未签到

发表于 2015-10-3 11:27:45 | 显示全部楼层 |阅读模式
  (原文地址:http://blog.iyunv.com/videosender/article/details/3137869)
  收集了一些我去微软 IBM google 笔试 面试的比较好的题目。大家可以练习一下,全都是c语言题目。

1. 写一个宏toStr,把一个宏定义的符号变为对应的宏定义内容的字符串。
比如
#define NAME jack
printf("NAME is %s\n", toStr(NAME));
会输出NAME is jack。
2. 接着第一题,扩展一下,写个宏printValue,实现上面的功能。
即: printValue(NAME);
就会输出 NAME is jack
3. 如果有个字符串数组, 写一个宏listString,打印出数组的所有字符串。比如
const char *names[] = {"jack","rose","mike"};
listString(names);
会输出
names[0] is jack
names[1] is rose
names[2] is mike
4. 如果用一个32位的unsigned long 表示一个可以包含32个元素的集合,对应位1表示有这个元素,0表示没有这个元素。最右边(地位)的元素编号0,最左边(最高位)的元素编号为31.
写一个宏findSetLeastMember,返回这个集合里最小的元素的编号,如果集合为空就返回32. 尽量优化。
比如 printf("%d",findSetLeastMember(0x00000054UL) ); 输出2
       printf("%d",findSetLeastMember(0x11000000UL) ); 输出 24
5. 写一个函数,char *ip2str(unsigned long ip_addr, char *str);把一个网络字节序的32位ip地址ip_addr转换为ip地址字符串str,str保证有16个char的空间,肯定能装下最多15个字符的ip地址字符,返回字符串的地址。可以用下面的程序验证是否正确:


  • char *ip2str(unsigned long ip_addr, char *str);
  • int main()
  • {  
  • unsigned int addr;
  • char ipStr[16];
  •   
  • srand((unsigned)time(0));  
  • for (int i = 0; i < 10; ++i){  
  • addr = rand();   
  • assert(addr == inet_addr(ip2str(addr, ipStr)));  
  • }  
  • return 0;
  • }
  6. 写一个函数int parseData(const char *str, Data *pData);其中Data定义为
typedef struct Data_tag{
char name[20];
short year;
short month;
short day;
} Data;
  这个函数读取字符串str,str的为一个名字和一个日期,比如"James Bond:1998/5/1",  "YaoMing:2007-11-4",  "Van der Vart:1989.3.5",名字可以是英文和数字,可以包括多个空格,最长19个字符,日期年月日排列,日期和名字用冒号(:)分隔,年月日之间可以用-或/或.分隔。解析这个字符串,把对应值放入pData所指的Data结构里,如果格式正确则返回0,否则返回-1.可以用下面的代码验证。
  typedef struct Data_tag{      
char name[20];      
short year;      
short month;      
short day;
} Data;
int parseData(const char *str, Data *pData);
int main()
{      
const char *istr[] = {      
"James Bond:1998/5/1",      
"Yao Ming:2007-11-4",      
"Van der Vart:1989.3.5",      
"lafa3245-23-4",/*error*/      
"Luis Carlo Taylor Tooooooolong121:2003/2/4"/*error*/      
};
  
Data data;      
for (int i = 0; i<sizeof(istr)/sizeof(istr[0]); ++i){      
printf("%s/n",istr);      
if (0 == parseData(istr, &data)){         
printf("name:%s, year:%d,month:%d,day:%d/n",data.name,data.year,data.month, data.day);      
}else {         
printf("format error/n");      
}
}
  return 0;
}
  7.如果我们想记录所有内存的分配和释放情况,比如说为了查内存泄露。程序里所有的内存都是用malloc申请,free释放。提供一个方法,把所有的调用malloc时得到的内存地址,大小,malloc语句所在的源代码文件名和所在的行数,以及所有的free的指针,文件名,行数都记录到malloc.log文件里。
8. 下面的C++代码演示了一个单件(singleton)模式,用c语言改写实现相同的效果
  class SingleOne
{
    SingleOne(void)
    {
        //???
    }
    ~SingleOne(void)
    {
        //????
    }
   
public:
    static SingleOne &getInstance(){
    static SingleOne instance;
    return instance;
}   
};
  好吧,我承认这些不是什么微软,IBM,google面试题,都是我自己出的,大家看着玩吧。
  
  部分参考答案,真的仅供参考:
  1.
  #define __toStr(n) #n
#define toStr(name) __toStr(name)
  
  4
  unsigned char BitRight[] =
          { 8,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            6,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            7,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            6,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,
            4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0 };
            
#define findSetLeastMember(Set)                     \
    (((Set) & 0xFFFF) ?                                     \
        (((Set) & 0xFF) ?                                   \
            BitRight[(Set) & 0xFF] :                \
            BitRight[((Set) >> 8) & 0xFF] + 8) :    \
        ((((Set) >> 16) & 0xFF) ?                           \
            BitRight[ ((Set) >> 16) & 0xFF] + 16 :  \
            BitRight[ (Set) >> 24] + 24)            \
    )

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-122068-1-1.html 上篇帖子: IBM 客户拜访模式及特色销售方法简介 下篇帖子: IBM的云存储技术
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表