这个题目使用位操作,该程序在取出一个数的最后一位是用到了与“&”运算;在更新这个数时用到了右移“>>”运算
核心:一个数&1,能求得其二进制的最后一位
如3&1
00000000000000000000000000000011 3
00000000000000000000000000000001 1
00000000000000000000000000000001 3的最后一位
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
while (1)//实现一直接收
{
int a = 0;
printf("请输入一个整数:\n");
scanf("%d", &a);
int i = 0;
int sum = 0;
int array[32] = { 0 };//创建数组存放二进制序列
for (i = 0; i <= 32; i++)//一个整数32比特位,因此控制32次
{
sum = a & 1;//&1便得到这个数的最后一位
if (sum == 1)
{
array[i] = 1;
}
else
{
array[i] = 0;
}
a = a >> 1;//右移更新二进制序列
}
for (i = 32; i >= 0; i--)//逆序输出
{
printf("%d", array[i]);
}
printf("\n");
}
return 0;
}