打印整数二进制的奇数位和偶数位

代码实现:

#include 
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

 

 

你可能感兴趣的:(c++,算法,蓝桥杯,后端,c语言)