elsehigh=mid-1;
}
return-1;
}
1.找错题
试题2:
voidtest2()
{
charstring[10],str1[10];
inti;
for(i=0;i<10;i++)
{
str1[i]='a';
}
strcpy(string,str1);
}
试题3:
voidtest3(char*str1)
{
charstring[10];
if(strlen(str1)<=10)
{
strcpy(string,str1);
}
}
库函数strcpy的工作方式,如果编写一个标准strcpy函数的总分值为10,下面给出几个不同得分的答案:
2分
voidstrcpy(char*strDest,char*strSrc)
{
while((*strDest++=*strSrc++)!
='’);
}
4分
voidstrcpy(char*strDest,constchar*strSrc)
//将源字符串加const,表明其为输入参数,加2分
{
while((*strDest++=*strSrc++)!
='’);
}
7分
voidstrcpy(char*strDest,constchar*strSrc)
{
//对源地址和目的地址加非0断言,加3分
assert((strDest!
=NULL)&&(strSrc!
=NULL));
while((*strDest++=*strSrc++)!
='’);
}
10分
//为了实现链式操作,将目的地址返回,加3分!
char*strcpy(char*strDest,constchar*strSrc)
{
assert((strDest!
=NULL)&&(strSrc!
=NULL));
char*address=strDest;
while((*strDest++=*strSrc++)!
='’);
returnaddress;
}
从2分到10分的几个答案我们可以清楚的看到,小小的strcpy竟然暗藏着这么多玄机,真不是盖的!
需要多么扎实的基本功才能写一个完美的strcpy啊!
再看看下面的一段程序有什么错误:
swap(int*p1,int*p2)
{
int*p;
*p=*p1;
*p1=*p2;
*p2=*p;
}
在swap函数中,p是一个“野”指针,有可能指向系统区,导致程序运行的崩溃。
在VC++中DEBUG运行时提示错误“AccessViolation”。
该程序应该改为:
swap(int*p1,int*p2)
{
intp;
p=*p1;
*p1=*p2;
*p2=p;
}
试题3:
写一个“标准”宏MIN,这个宏输入两个参数并返回较小的一个。
另外,当你写下面的代码时会发生什么事?
least=MIN(*p++,b);
解答:
#defineMIN(A,B)((A)<=(B)?
(A):
(B))
MIN(*p++,b)会产生宏的副作用
剖析:
这个面试题主要考查面试者对宏定义的使用,宏定义可以实现类似于函数的功能,但是它终归不是函数,而宏定义中括弧中的“参数”也不是真的参数,在宏展开的时候对“参数”进行的是一对一的替换。
程序员对宏定义的使用要非常小心,特别要注意两个问题:
(1)谨慎地将宏定义中的“参数”和整个宏用用括弧括起来。
所以,严格地讲,下述解答:
#defineMIN(A,B)(A)<=(B)?
(A):
(B)
#defineMIN(A,B)(A<=B?
A:
B)
都应判0分;
(2)防止宏的副作用。
宏定义#defineMIN(A,B)((A)<=(B)?
(A):
(B))对MIN(*p++,b)的作用结果是:
((*p++)<=(b)?
(*p++):
(*p++))
这个表达式会产生副作用,指针p会作三次++自增操作。
除此之外,另一个应该判0分的解答是:
#defineMIN(A,B)((A)<=(B)?
(A):
(B));
这个解答在宏定义的后面加“;”,显示编写者对宏的概念模糊不清,只能被无情地判0分并被面试官淘汰。
试题5:
编写一个函数,作用是把一个char组成的字符串循环右移n个。
比如原来是“abcdefghi”如果n=2,移位后应该是“hiabcdefgh”
函数头是这样的:
//pStr是指向以''结尾的字符串的指针
//steps是要求移动的n
voidLoopMove(char*pStr,intsteps)
{
//请填充...
}
解答:
正确解答1:
voidLoopMove(char*pStr,intsteps)
{
intn=strlen(pStr)-steps;
chartmp[MAX_LEN];
strcpy(tmp,pStr+n);
strcpy(tmp+steps,pStr);
*(tmp+strlen(pStr))='';
strcpy(pStr,tmp);
}
正确解答2:
voidLoopMove(char*pStr,intsteps)
{
intn=strlen(pStr)-steps;
chartmp[MAX_LEN];
memcpy(tmp,pStr+n,steps);
memcpy(pStr+steps,pStr,n);
memcpy(pStr,tmp,steps);
}
剖析:
这个试题主要考查面试者对标准库函数的熟练程度,在需要的时候引用库函数可以很大程度上简化程序编写的工作量。
最频繁被使用的库函数包括:
(1)strcpy
(2)memcpy
(3)memset
FuYu注释:
这两种方法都很业余,都是算法能力差的人给出的答案,都要用chartmp[MAX_LEN]这么多辅助空间,“MAX_LEN”是多么好笑的用法。
标准答案是对倒、对倒、再对倒。
试题1:
请写一个C函数,若处理器是Big_endian的,则返回0;若是Little_endian的,则返回1
解答:
intcheckCPU()
{
{
unionw
{
inta;
charb;
}c;
c.a=1;
retu