[英]Binary representation of a number in C
我遇到了这个代码,用于表示数字的二进制表示。 我想知道使用的必要性!! 在代码中。
int main() {
int n,i;
unsigned flag = 1<<(sizeof(int) * 8 - 1);
printf("Input the number\n");
scanf("%d",&n);
for(i=0;i<sizeof(int)*8;i++) {
printf("%d",!!(n & flag) );
n = n << 1;
}
return 0;
}
!!
将任何非零值转换为1,并将零值保留为零。
x = 0;
y = 50;
!x; // 1
!y; // 0
!!x; // 0
!!y; // 1
这是一个穷人的布尔演员。
使用的标志只有MSB设置而所有其他位都被清除,所以当你bitwise and
它和数字你可以测试数字中的MSB。
按位和结果有两种结果:
现在我们需要一种映射方式
Non-zero -> 1
Zero -> 0
所以我们使用双重否定。
可以使用以下方法完成同样的事情:
for(i=0;i<sizeof(int)*8;i++) {
(n & flag) ? printf("1"):printf("0");
n = n << 1;
}
我会写!!x
更容易混淆,因为x != 0
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.