题目:获取一个整数二进制序列中所有的偶数位和奇数位,分别打印出二进制序列
拿到这个问题首先我们要好好的理解一下题意,获取一个整数二进制序列中所有的偶数位和奇数位,我们知道二进制序列在计算机中的存储有32位,例如11的二进制序列就是00000000000000000000000000001011,而他的奇数位和偶数位各占16位。奇数位就是这32位单数位的数,偶数位就是双数位的数。像这个二进制序列的奇数位就是00000000000000001.当然偶数位就是0000000000000011.
其实剖析之后不难发现这道题的本质是想考察我们打印一个数的二进制位,这个过程我们可以通过移位和与操作符来实现。
最后将结果打印到屏幕上,打印的方法我们是这样实现的。把要打印的那一位和1相与的结果就是它本身,所以我们只需通过移位操作让要打印的位数和1相与就能把这一位成功的打印到屏幕上了。
代码如下:
#include <stdio.h>
int main()
{
int m = 0;
scanf("%d", &m);
//11
//00000000000000000000000000001011
int i = 0;
//偶数位
for (i = 31; i >= 1; i -= 2)
{
printf("%d ", (m >> i) & 1);
}
printf("\n");
//奇数位
for (i = 30; i >= 0; i -= 2)
{
printf("%d ", (m >> i) & 1);
}
return 0;
}