华为机试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;
}
相关推荐
一只_程序媛2 分钟前
【leetcode hot 100 300】最长递增子序列
算法·leetcode·职场和发展
岁ovo寒5 分钟前
c++day7
开发语言·c++·算法
Kita~Ikuyo20 分钟前
基础数学:线性代数与优化理论
人工智能·线性代数·算法·机器学习
.YY001.1 小时前
关于数据结构B树部分的知识点,解题过程以及方法思路
数据结构
小森77671 小时前
(四)机器学习---逻辑回归及其Python实现
人工智能·python·算法·机器学习·逻辑回归·线性回归
小阳拱白菜2 小时前
蓝桥杯刷题--挖矿
算法·职场和发展·蓝桥杯
补三补四2 小时前
【深度学习基础】——机器的神经元:感知机
人工智能·深度学习·算法·机器学习
ZHW_AI课题组2 小时前
基于线性回归模型的汽车燃油效率预测
算法·汽车·线性回归
烁3472 小时前
每日一题(小白)暴力娱乐篇29
java·数据结构·算法·娱乐
梭七y2 小时前
【力扣hot100题】(080)爬楼梯
算法·leetcode·职场和发展