代码实现:
#include <stdio.h>
void Print(int m)
{
int i = 0;
//打印奇数位
for (i = 30; i >= 0; i -= 2)//移动0,2,4,6
{
printf("%d ", (m >> i) & 1);
}
printf("\n");
//打印偶数位
for (i = 31; i >= 1; i -= 2)//移动1,3
{
printf("%d ", (m >> i) & 1);
}
}
int main()
{
int m = 0;
scanf("%d", &m);
Print(m);
return 0;
}
// 输入:201
//(其实是00000000000000000000000011001001)
// 输出: 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1
// 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0
题目理解:
获取一个整数二进制序列中所有的偶数位和奇数位,分别打印出二进制序列。
思路讲解:
1. 提取所有的奇数位,如果该位是1,输出1,是0则输出0 |
2. 以同样的方式提取偶数位置 |
检测num中某一位是0还是1的方式: |
1. 将num向右移动i位 |
2. 将移完位之后的结果与1按位与,如果: |
结果是0,则第i个比特位是0 |
结果是非0,则第i个比特位是1 |