#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的个数。这种方法简单通俗易懂,更容易理解一些
时间: 2024-10-06 23:24:14