描述

ACM俱乐部里员工的都有一个工号,这个工号的二进制表达中1的个数越多,这个员工的级别就越高。
输入一个工号,求这个工号的二进制表达中1的个数。
例如输入10,由于其二进制表示为1010,有两个1,因此输出2。

输入

每组测试数据输入一行,每行输入一个整数(绝对值<=1000000)。

输出

每组测试数据输出一行,这个工号的二进制表达中1的个数。

样例输入1

10
0
-32768

样例输出1

2
0
17

#include <stdio.h> 
int main()  
{  
    int n;  
    while(scanf("%d",&n)!=EOF)  
	{
		unsigned int count=0,flag=1;
		while(flag&&flag<=n)  
		{  
			if(n&flag)  
				count++;  
			flag<<=1;  
		}
		printf("%d\n",count);  
	}
    return 0;  
}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论