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

C语言-操作符-典型例题多种解法(求一个数二进制中1的个数)

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

C语言-操作符-典型例题多种解法(求一个数二进制中1的个数)

2021_11_18

第一种方法:采取的是取余、再除法

(此做法就类似于对于一个十进制的数,如何得到它的每一位)

#include 

int count_number_if_1(unsigned int n)
{
	int c = 0;
	while (n)
	{
		if (1 == (n % 2))
		{
			c++;
		}
		n /= 2;
	}
    return c;
}

int main()
{
	int n = 0;
	scanf("%d", &n);
	int ret = count_number_of_1(n);
	printf("%dn", ret);
	return 0;
}

第二种方法: 利用 & 按位与操作符(两数同为都为1才为1)

                   

#include 

int count_number_of_1(int n)
{
	int c = 0;
	while (n)
	{
		if (1 == (n & 1))
		{
			c++;
		}
		n >>= 1;
	}
	return c;
}


int main()
{
	int n = 0;
	scanf("%d", &n);
	int ret = count_number_of_1(n);
	printf("%dn", ret);
	return 0;
}
 第三种方法:

#include 

int count_number_of_1(int m)
{
	int c = 0;
	while (m)
	{
		m = m & (m - 1);
		c++;
	}
	return c;
}


int main()
{
	int n = 0;
	scanf("%d", &n);
	int ret = count_number_of_1(n);
	printf("%dn", ret);
	return 0;
}

 

 

                     

    

  

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

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

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