华为机试HJ62 查找输入整数二进制中1的个数

首先看一下题

描述

输入一个正整数,计算它在二进制下的1的个数。

注意多组输入输出!!!!!!

数据范围: 1≤n≤2^31−1

输入描述:

输入一个整数

输出描述:

计算整数二进制中1的个数

示例1

输入:

复制代码
5

输出:

复制代码
2

说明:

复制代码
5的二进制表示是101,有2个1   

示例2

输入:

复制代码
0

输出:

复制代码
0

一、问题分析

首先读题,仔细看描述中的内容,发现需求是

1.输入一个正整数,计算它在二进制下1的个数

2.数据范围:n大于等于1小于等于2的31次方减1

3.输入描述:输入一个整数

4.输出描述:计算整数二进制中1的个数

二、解题思路

1.我们可以使用位操作

2.先包含标准输入输出库

#include <stdio.h>

3.然后进入主程序

int main(){

4.定义一个整数int n;

5.读取数据while(scanf("%d", &n) != EOF) {

6.定义一个计数器int counter = 0;

7.当我们这个整数不为0的时候继续循环

while(n != 0) {

if(n & 1) counter++;

n >>= 1;

}

printf("%d\n", counter);

}

return 0;

}

三、具体步骤

使用的语言是C

cpp 复制代码
#include <stdio.h>

int main() {
    int n;
    while (scanf("%d", &n) != EOF) {
        int counter = 0;
        while(n != 0) {
            if(n & 1) counter++;
            n >>= 1;
        }
        printf("%d\n", counter);
    }
    return 0;
}
相关推荐
Skrrapper19 小时前
【STL】set、multiset、unordered_set、unordered_multiset 的区别
c++·算法·哈希算法
SunnyKriSmile19 小时前
函数递归求最大值
c语言·算法·函数递归
傻啦嘿哟19 小时前
爬虫数据去重:BloomFilter算法实现指南
爬虫·算法
立志成为大牛的小牛19 小时前
数据结构——三十六、拓扑排序(王道408)
数据结构·学习·程序人生·考研·算法
懒羊羊不懒@20 小时前
JavaSe—List集合系列
java·开发语言·数据结构·人工智能·windows
爱笑的眼睛1120 小时前
深入探索HarmonyOS文件压缩与解压缩API:从基础到高级应用
华为·harmonyos
绛洞花主敏明1 天前
Go切片的赋值
c++·算法·golang
10001hours1 天前
初阶数据结构.1.顺序表.通讯录项目(只有源码和注释)
数据结构·算法
鸿蒙小白龙1 天前
OpenHarmony Location Kit技术详解:定位、地理围栏与编码转换
华为·harmonyos·open harmony
Emilia486.1 天前
八大排序算法
算法·排序算法