收集了一些我去微软 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",findSetL
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",findSetL