12.inti=(int)((unsigned int)0xffffffff+(unsigned int)0xffffffff);
printf(“%d”,i);结果是:C
A.0 B.-1 C.-2 D.2
1.求下面函数的返回值
int func(int a)
{
int count=0;
while(a)
{
count++;
a=a&(a-1);
}
return count;
}
假设a=911,则函数返回值是:7
可以看到,我们到底什么时候用原码,什么时候用补码计算呢?
其实很简单,
当题目给出int x=0x123等等直接用二进制表示的数据时,就用补码计算,
如果给出那种用十进制常量赋值后,再进行位运算等等,全部用原码计算就行,我们可以封装黑盒地看待补码转换
有了以上两个原则,第二题实际上就是将a的原码的最右边的1变为0,一直到全部的1都变为0