统计一个数二进制中1的个数

直接上代码

方法一

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int count_1(unsigned int a)//unsigned int正负数通用
{
	int count = 0;
	while (a)
	{
		if (a % 2 == 1)
		{
			count++;
		}
		a = a / 2;//eg:输入:16/2-->8/2-->4/2-->2/2-->1%2=1(count=1)-->1/2=0(退出循环)
	}
	return count;
}
int main()
{
	int a = 0;
	scanf("%d", &a);
	int ret = count_1(a);
	printf("%d\n", ret);
	return 0;
}

方法二

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
方法二
int count_1(int m)
{
	int c = 0;//统计1的个数
	int i = 0;
	for (i = 0; i < 32; i++)
	{
		if ((m & 1) == 1)//判断二进制最后一位是不是1
		{
			c++;
		}
		m >>= 1;//由于右移后是在左边补符号位(vs编译器),不会影响&的运算
	}
	return c;
}
int main()
{
	int a = 0;
	scanf("%d", &a);
	int ret = count_1(a);
	printf("%d\n", ret);
	return 0;
}

注意

一.关于右移操作符:

1算术右移(右边丢弃,左边补原来的符号位(1/0))

2逻辑右移(右边丢弃,左边补0)

存在那种取决于编译器(vs是算术右移)

对移位操作符,不要移动负数位,这个是标准未定义的。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
//方法三
int count_1(int m)
{
	int c = 0;
	while (m)
	{
		m = m&(m - 1);
		c++;

	}
	return c;
}


int main()
{
	int a = 0;
	scanf("%d", &a);
	int ret = count_1(a);
	printf("%d\n", ret);
	return 0;
}
//eg:m=16
m             001111(补码后几位)
m-1           001110
m=m&(m-1)     001110
m-1           001101
m=m&(m-1)    001100
m-1           001011
m=m&(m-1)     001000
m-1           000111
m             000000//到0之前总共变了四次

同时

(m&(m-1))==0还可以判断m是2^k(二进制位中只有一个1)

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值