求二进制中1的个数

#include
#include
//方法一:
int Numberof1(int n)
{
	int count = 0;
	while(n)
	{
		if(n & 1)
			count++;
		n = n >> 1; //位操作比乘除运算效率高。
	}
	return count;
}
//上面的程序如果传入的n是一个负数,将造成死循环。因为负数移位时要保留符号位。


//方法二:
int _Numberof1(int n)
{
	int flag = 1;
	int count = 0;
	while(flag)   //循环的次数与n的位数有关,时间复杂度高
	{
		if(n & flag)
			count++;
		flag = flag<<1;
	}
	return count;
}

//方法三:
int __Numberof1(int n)
{
	int count = 0;
	while(n)  //有多少个1循环多少次,比较高效
	{
		count++;
		n = n & (n-1);
	}
	return count;
}
int main()
{
	int sum = 20;
	int num1 = Numberof1(sum);
	int num2 =_Numberof1(sum);
	int num3 =__Numberof1(sum);

	printf("%d,%d,%d\n",num1,num2,num3);
	system("pause");
	return 0;
}

总结:

创新互联公司为您提适合企业的网站设计 让您的网站在搜索引擎具有高度排名,让您的网站具备超强的网络竞争力!结合企业自身,进行网站设计及把握,最后结合企业文化和具体宗旨等,才能创作出一份性化解决方案。从网站策划到网站建设、成都做网站, 我们的网页设计师为您提供的解决方案。

一般进行二进制操作时,都可以采用先-1,再按位与的方法。-1相当于从最右边的1到最低位,全都按位取反,再与的话,就把最右边的1置为0.


本文题目:求二进制中1的个数
文章来源:http://bzwzjz.com/article/pgjdde.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站建设公司 梓潼网站设计 响应式网站建设 网站建设方案 定制级高端网站建设 重庆网站建设 app网站建设 成都响应式网站建设 攀枝花网站设计 重庆网站建设 公司网站建设 商城网站建设 网站设计制作报价 成都网站制作 成都网站建设 外贸营销网站建设 成都网站建设 成都网站设计 成都网站建设推广 成都网站建设流程 网站制作报价 高端网站设计推广