返回一个参数中二进制数中1的个数

#include<stdio.h>
#include<stdlib.h>

int _Count(int n)
{
	int arr[30];
	int i=0;
	int j=0;
	int m=0;
	while(n)
	{
		arr[i++]=n%2;
		n=n/2;
		j++;
	}	
	for(i=0;i<=j;i++)
	{	
		if((arr[i]^1)==0)
		m++;
	}
	return(m);
	}

int main()
{
	int num;
	int count=0;
	printf("请输入一个数:");
	scanf_s("%d",&num);
	count=_Count(num);
	printf("count=%d\n",count);
	system("pause");
	return 0;
}


//这种解法是先将一个十进制的数字转换为二进制的数字并将其保存在一个数组中,然后将数组中的数字与“1”异或,根据“相同为0相异为1”的原则计算出其中1的个数。这种方法简单通俗易懂,更容易理解一些

//但是这种解决方法却存在弊端,也就是说它是不完整的,它不能计算负数。下面就是对其的完善



#include<stdio.h>
#include<stdlib.h>

int main()
{
	int num;
	int i=0;
	int count=0;
	printf("请输入一个数:");
	scanf("%d",&num);
	for(i=0;i<32;i++)
	{
		if((num&1)==0)
			count++;
			num>>=1;
	}
	printf("%d\n",count);
	system("pause");
	return 0;
}


//思路:由于数字在计算机中是以二进制的形式存储的,并且进行相与或者异或运算时是按二进制位进行的,因此可以采取此种特性,让 num 与1进行与运算,然后让计算过的 num 右移一位,这样就可以计算出 num 的二进制位中有多少数字 1



最优化方法:


int count_one_bit(int n)
{
	int count=0;
	while(num)
	{
		count++;
		num=num&(num-1);
	}
	return count;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值