力扣191. 位1的个数

给定一个正整数 n,编写一个函数,获取一个正整数的二进制形式并返回其二进制表达式中

设置位 的个数(也被称为汉明重量)。


示例 1:

复制代码
输入:n = 11
输出:3
解释:输入的二进制串 1011 中,共有 3 个设置位。

示例 2:

复制代码
输入:n = 128
输出:1
解释:输入的二进制串 10000000 中,共有 1 个设置位。

示例 3:

复制代码
输入:n = 2147483645
输出:30
解释:输入的二进制串 1111111111111111111111111111101 中,共有 30 个设置位。

提示:

  • 1 <= n <= 231 - 1

进阶

  • 如果多次调用这个函数,你将如何优化你的算法?

代码:

cpp 复制代码
class Solution {
public:
    int hammingWeight(int n) {
        int cnt;

        while(n){
            cnt += n%2;
            n = n/2;
        }

        return cnt;
    }
};

解题思路:

(1)根据题意,只需计算输入 n 的二进制表示中,有几个1。

(2)只要进行模2运算,即可判断余数是否为1。

(3)每次循环 n 除以 2。

相关推荐
再卷也是菜19 小时前
C++篇(21)图
数据结构·c++·算法
星轨初途19 小时前
C++入门(算法竞赛类)
c++·经验分享·笔记·算法
灰灰勇闯IT20 小时前
KMP算法在鸿蒙系统中的应用:从字符串匹配到高效系统级开发(附实战代码)
算法·华为·harmonyos
小龙报20 小时前
【算法通关指南:数据结构和算法篇 】队列相关算法题:3.海港
数据结构·c++·算法·贪心算法·创业创新·学习方法·visual studio
csuzhucong20 小时前
一阶魔方、一阶金字塔魔方、一阶五魔方
算法
五花就是菜20 小时前
P12906 [NERC 2020] Guide 题解
算法·深度优先·图论
辞旧 lekkk21 小时前
【c++】封装红黑树实现mymap和myset
c++·学习·算法·萌新
星轨初途21 小时前
C++的输入输出(上)(算法竞赛类)
开发语言·c++·经验分享·笔记·算法
n***F87521 小时前
SpringMVC 请求参数接收
前端·javascript·算法
Liangwei Lin21 小时前
洛谷 P1025 [NOIP 2001 提高组] 数的划分
算法