题解:统计某数中二进制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