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

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

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;
}

 

 

                     

    

  

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5580746.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-14
下一篇2022-12-14

发表评论

登录后才能评论

评论列表(0条)

    保存