码迷,mamicode.com
首页 > 其他好文 > 详细

求二进制中1的个数

时间:2016-04-15 15:35:24      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:位操作


#include<stdio.h>
#include<stdlib.h>
//方法一:
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://fengbaoli.blog.51cto.com/10538178/1764157

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!