【十二题解】 | #查找输入整数二进制中1的个数#

查找输入整数二进制中1的个数

http://www.nowcoder.com/practice/1b46eb4cf3fa49b9965ac3c2c1caf5ad

#include<stdio.h>

int main(){

int number;
while(scanf("%d", &number) !=EOF){
    int count = 0;
    for(int i=0; i<31; i++){
        if(number & 1 == 1)count++;
        number >>= 1;
    }
    printf("%d\n", count);
}

}

全部评论
int是32位的,题目要求是n位正数,所以最高位符号位一定为0,所以代码中i<31,不看最高位符号位。
点赞 回复 分享
发布于 04-21 10:31 黑龙江
# include <stdio.h> int main() { int number; while (scanf("%d", &number) != EOF) { int count = 0; for (int i = 0; i < 31; i++) { if ((number & 1) == 1) count++; number >>= 1; } printf("%d\n", count); } }</stdio.h>
点赞 回复 分享
发布于 07-09 01:59 重庆

相关推荐

点赞 评论 收藏
分享
8 1 评论
分享
牛客网
牛客企业服务