例如:
整数5
二进制:00000000 00000000 00000000 00000101
从右端开始首位为偶数位,第二位开始为奇数位。即0123:0,2为偶1,3为奇
奇数位:0000000000000000
偶数位:0000000000000011
拿奇数位举例,开始i=31,num向右移动31位,来到左端第一位:0(左边补齐什么暂且不管),得到的数字再与1按位与(同时为1结果为1,任一方为0结果为0) ,得到右移后最右端的数字并打印,注意num没有进行赋值变化。
当i = 1时,num右移1位,最右端变为0,再与1按位与,得到右移后最右端的数并打印。如果不与1进行按位与操作直接打印则会打印右移后的整个32位二进制num
//将二进制位向右移i个,再与1按位与,得到最右端的数字
//一次打印一个数字
int main()
{
int num = 5;
//奇数位
for (int i = 31; i >= 1; i -= 2)
{
printf("%d", (num >> i) & 1);
}
printf("\n");
//偶数位
for (int i = 30; i >= 0; i -= 2)
{
printf("%d", (num >> i) & 1);
}
return 0;
}