此题的解决思路为:将某一个数通过将其二进制位右移,并按位与1,即可获得每个二进制位上的值。奇数位与偶数位的实现可以通过右移的个数来确定。
奇数位:右移0/2/4....位,按位与1(从第30位开始)
偶数位:右移1/3/5....位,按位与1(从第31位开始)
具体代码如下:
#define _CRT_SECURE_NO_DEPRECATE
#include <stdio.h>
#include <stdlib.h>
int main()
{
//00000000 00000000 00000000 00001010
//奇数位:右移0/2/4....位,按位与1(30)
//偶数位:右移1/3/5....位,按位与1(31)
int n = 0;
printf("请输入数字:");
scanf("%d", &n);
int i = 0;
printf("奇数位为:");
for (i = 30; i >= 0; i -= 2)
{
printf("%d ", (n >> i)&1);
}
printf("\n");
printf("偶数位为:");
for (i = 31; i >= 0; i -= 2)
{
printf("%d ", (n >> i)&1);
}
printf("\n");
system("pause");
return 0;
}