解题思路:打印一个整数的二进制位中的偶数位和奇数位,可以对整数进行移位操作,再将移位的二进制位与1
进行&
操作。
按位&
,同为1则为1,不同为1时则为0。
如:
//0000 0000 0000 0000 0000 0000 0000 0001
//0000 0000 0000 0000 0000 0000 1100 0111 199
如这个数,对这个数进行移位操作,每移一位就可得到这个数的二进制位。但是我们需要的是,偶数位和奇数位进行分别输出,所以就需要每一次移两位。
#include <stdio.h>
#include <Windows.h>
#pragma warning(disable:4996)
#include <time.h>
#include <stdlib.h>
void All1(int m);
int main()
{
int x = 199;
All1(x);
return 0;
}
void All1(int m)
{
int i = 0;
i = 31;
printf("二进制:");
while (i >= 0)
{
printf("%d ", (m >> i) & 1);
i--;
}
printf("\n奇数位:");
for (i = 0; i <=30; i += 2)
{
printf("%d ", (m >> i) & 1);
}
printf("\n偶数位:");
for (i = 1; i <= 31; i += 2)
{
printf("%d ", (m >> i) & 1);
}
printf("\n");
}
输出结果为:
这是先从低位向右移位,但这样不利于观看,做一点优化。
先对整个数进行移位。偶数位第一次移31位,每次减2。奇数位第一次移30位,每次减2。
#include <stdio.h>
#include <Windows.h>
#pragma warning(disable:4996)
#include <time.h>
#include <stdlib.h>
void All(int m);
int main()
{
int x = 199;
All(x);
return 0;
}
void All(int m)
{
int i = 0;
i = 31;
printf("二进制:");
while (i>=0)
{
printf("%d ", (m >> i) & 1);
i--;
}
printf("\n奇数位:");
for (i = 30; i >= 0; i -= 2)
{
printf("%d ", (m >> i) & 1);
}
printf("\n偶数位:");
for (i = 31; i >= 1; i -= 2)
{
printf("%d ", (m >> i) & 1);
}
}
结果为: