#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int num_of_1(int n)
{
//int count = 0;
//while (n)
//{
// if (n % 2 == 1)
// {
// count++;
// }
// n /= 2;
//}
//return count; // 由于负数的反码特殊,所以函数接收调整为无符号整形
//int count = 0;
//while (n)
//{
// if (n & 1 == 1)
// {
// count++;
// }
// n >>= 1; // 由于负数的进制位移动时左边可能不补零,所以函数接收调整为无符号整形
//}
//return count;
//2.与运算+位运算 > (改进型,对整形的正负无要求)
int count = 0;
int i = 0;
for (i = 0; i < 32; i++)
{
if (((n >> i) & 1 ) == 1)
{
count++;
}
}
return count;
//3. x & (x-1) 特殊运算
//int count = 0;
//while (n)
//{
// n = n & (n - 1);
// count++;
//}
//return count;
}
//统计二进制中 '1' 的个数
int main()
{
//输入10进制整数
int input = 0;
printf("请输入整数:");
scanf("%d", &input);
//计算并输出
int ret;
ret = num_of_1(input);
printf("%d 的二进制格式中'1'的个数为:%d\n", input, ret);
return 0;
}