用c语言实现输入一个十进制数,计算其转换为二进制数后其中包含1的个数

这个问题有两个解决方法。第一个就是用我们平时十进制转换二进制的算法,即短除法。

第二个就是用其本身与上其二进制数减一,

例如:x&(x-1)      当x=5时, 5的二进制是0101   

0101 & (0101-1)   ==   0101 & 0100 == 0100

0100 & (0100-1)   ==   0100 & 0011 == 0000

一共计算了两次,也就是说5的二进制数一共只有2个1.

下面是代码实现:

#include<stdio.h>
int count_bits(unsigned int value)//定义形参
{
	
	int one = 0;//定义计数器
	while(value != 0)
	{
		if(value % 2 == 1)//短除法计算
		{
			one ++;
			value = value / 2;
		}
	}
	return one;
}
int main()
{
	int ret = 0;
	ret = count_bits(15);//调用函数
	printf("%d\n",ret);
	return 0;
}


这是第二种算法:

#include<stdio.h>
int count_bit(unsigned int value)
{
	int count = 0;
	while(value)
	{
		count++;
		value = value & (value - 1);//value与其二进制减1,结果再赋给value
	}
	return count;//返回计数器
}

int main()
{
	int ret = 0;
	ret = count_bit(5);
	printf("%d\n",ret);
	return 0;
}


  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值