题解:统计某数中二进制1的个数(取模法 + 看某位是1/0法 + 干掉最右边的1法)
目录
- 1.题目
- 2.取模法
- 3.看某位是1/0
- 4.干掉最右边的1
1.题目
题目:设计一个程序,统计某数中二进制1的个数
2.取模法
int main()
{
	int num = 15;
	int count = 0;
	while (num)
	{
		if (num % 2 == 1) count++;
		num /= 2;
	}
	printf("count = %d\n", count);
	return 0;
}
缺点:当num < 0时,result error!!!
 示例:
 
3.看某位是1/0
确定某一位是0/1,公式如下
 公式:ret = (n >> i) & 1
 详情:LINK
int main()
{
	int num = -1;
	int count = 0;
	int i = 0;
	while (i < 32)
	{
		if (((num >> i) & 1) == 1) count++;
		i++;
	}
	printf("count = %d\n", count);
	return 0;
}
4.干掉最右边的1
干掉二进制最右边的1,公式如下:
 公式:ret = n & (n - 1)
 详情:LINK
int main()
{
	int num = -1;
	int count = 0;
	while (num)
	{
		num = (num & (num - 1));
		count++;
	}
	printf("count = %d\n", count);
	return 0;
}
EOF


















