栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

计算一个数对应的二进制数中1的个数

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

计算一个数对应的二进制数中1的个数

文章目录
  • 一、右移运算与&运算
  • 二、具体实现
    • 1.代码
    • 2.运行结果


一、右移运算与&运算

对于无符号数,无论是逻辑右移还是算数右移,右边均补0,所以通过将一个无符号数不停的执行右移运算,可以将一个数的每一位依次移动到个位上(相当于执行/10的操作)。
通过A&1=A、A&0=0可以用来测试某一位的数值是1还是0

二、具体实现 1.代码

代码如下(示例):

#include 

int main()
{
	unsigned int a, count=0;
	printf("输入a的值");
	scanf("%d", &a);
	for (count = 0; a != 0; a >>= 1)  //将次末位变为末位 
	{
		if ((a & 1) != 0)  //测试最末位是否为1 也可以写成if((a%2) != 0)
		{
			count++;
		}
	}
	printf("count = %dn", count);
	
	return 0;
}
2.运行结果

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/691057.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号