随手一练

1:返回参数二进制中1的个数
int count_one_bits(unsigned int value)
{
int count = 0;
while (value)
{
if ((value & 1) == 1)
count++;
value = value >> 1;
}
return count;
}
int main()
{
unsigned int num = 0;
scanf("%d", &num);
printf("%d\n", count_one_bits(num));

system("pause");
return 0;

}
2输出整数的二进制数位的偶数位,奇数位和二进制序列。
int main()

{

int i = 0;
int j = 0;
int a[16] = { 0 };
int b[16] = { 0 };
int num = 0;

printf("请输入要计算的数值");

scanf("%d", &num);

for(i =0,j  = 0; j < 32; i++, j += 2)

{

	a[15 - i] = (num >> j) & 1;

}

printf("奇数位为:");

for(i = 0; i < 16; i++)

{

	printf("%d", a[i]);

}

for(i = 0, j = 1; j < 32; i++, j += 2)

{

	b[15 - i] = (num >> j) & 1;

}

printf("\n");

printf("偶数位为:");

for(i = 0; i < 16; i++)

{

	printf("%d", b[i]);

}

printf("\n");

printf("二进制序列为:\n");

for(i = 0; i < 16; i++)

{

	printf("%d%d", b[i], a[i]);

}

getchar();

system("pause");

return 0;

}
3:输出整数的每一位。
int num = 0;
int i = 0;
int a[32] = { 0 };
printf(“请输入要计算的数值”);

scanf("%d", &num);

for (i = 0; i < 16; i++)

{

	printf("%d", a[i]);

}


getchar();

4两个 int 整数m和n的二进制表达中,有多少个bit位不同。
int main()
{
int a = 0;
int b = 0;
int count = 0;//对位数计数
int count1 = 0;//计不相同的位
int num = 0;
int arr[32] = { 0 };
int i = 0;
printf(“请输入两个整数:”);
scanf("%d%d", &a, &b);
num = a^b;
while (num)
{
arr[i] = num % 2;
num = num / 2;
i++;
count++;
}
for (i = 0; i <= count; i++)
{
if (1 == arr[i])
{
count1++;
}
}
printf(“不相同的位有:%d位\n”, count1);
system(“pause”);
return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值