如何利用c返回一个参数中其二进制数中1的个数
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何利用c返回一个参数中其二进制数中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的个数。这种方法简单通俗易懂,更容易理解一些
以上是关于如何利用c返回一个参数中其二进制数中1的个数的主要内容,如果未能解决你的问题,请参考以下文章
C++ 计算二进制数中1的个数 可用于负数 无符号数 且无需遍历整数所有位