【十二题解】 | #查找输入整数二进制中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,不看最高位符号位。
2 回复 分享
发布于 2024-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>
点赞 回复 分享
发布于 2024-07-09 01:59 重庆

相关推荐

不愿透露姓名的神秘牛友
昨天 16:22
点赞 评论 收藏
分享
点赞 评论 收藏
分享
05-12 17:00
门头沟学院 Java
king122:你的项目描述至少要分点呀,要实习的话,你的描述可以使用什么技术,实现了什么难点,达成了哪些数字指标,这个数字指标尽量是真实的,这样面试应该会多很多,就这样自己包装一下,包装不好可以找我,我有几个大厂最近做过的实习项目也可以包装一下
点赞 评论 收藏
分享
评论
8
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务