1.
//结果是什么?
int main()
{
unsigned char i = 7;
int j = 0;
for (; i > 0; i -= 3)
{
++j;
}
printf("%d\n", j);
return 0;
}
unsigned char的范围是0-255
所以这个循环停止的条件是i==0就停止
i 从7开始,所以肯定会进入第一次循环,就变成了i=4
然后i=1,最后i=-2
但是最后i不会等于-2,因为他无符号的,他会变成254
-2
10000000000000000000000000000010
11111111111111111111111111111101
11111111111111111111111111111110
11111110
就这样依次往下走, 我依次-3,要多少次才能到0呢?
7 3 1 254 251…………254/3=84。也就是说可以除84次。当254-84*3的时候,等于2,说明还剩一个2。最后-3又变成了-1,也就是255(共85次)
255这样一直-3,可以减85个,255-85*3就刚好等于0。(85次)
所以需要85+85+3=173次
2.
哪一个一定可以将flag第二个bit置0?
A.flag &= ~2
B.flag |= 2
C.flag ^= 2
D.flag >>= 2
A. 00000010
~是取反: 111111101
按位与时,只有第二个数变了,所以A正确
3.
void main()
{
int a = -3;
unsigned int b = 2;
long c = a + b;
printf("%ld\n", c);
}
答案是什么?
int a = -3;
10000000000000000000000000000011//原
11111111111111111111111111111100//反
11111111111111111111111111111101//补
unsigned int b = 2;
00000000000000000000000000000010
11111111111111111111111111111101
00000000000000000000000000000010相加后的结果就是11111111111111111111111
然后变回原码,其实就是-1
这道题错在没有把补码变回原码了
4.
int fun(int a)
{
a^=(1<<5)-1;
return a;
}
fun(21)运行的结果是多少?
先算1<<5的结果:
00000001
00100000 <<后
00011111 -1后10101和11111异或的结果是
1111101010,结果是10
5.
由多个源文件组成的C程序,经过编辑、预处理、编译、链接等阶段会生成最终的可执行程序。下面哪个阶段可以发现被调用的函数未定义:
A预处理
B编译
C链接
D执行正确答案:C
[编程题]替换空格*
请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
后期详解