【LC】191. 位1的个数

题目描述:

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

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

示例 1:

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

示例 2:

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

示例 3:

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

题解:

复制代码
class Solution {
    public int hammingWeight(int n) {
        int count = 0;
        while (n != 0) {
            // 二进制最后一位
            count += n & 1;
            n >>= 1;
        }
        return count;
    }
}
相关推荐
better_liang12 小时前
每日Java面试场景题知识点之-MySQL索引
java·数据库·mysql·性能优化·索引
Yzzz-F12 小时前
2025 ICPC武汉邀请赛 G [根号分治 容斥原理+DP]
算法
abant212 小时前
leetcode 114 二叉树变链表
算法·leetcode·链表
tankeven12 小时前
HJ165 小红的优惠券
c++·算法
Aktx20FNz12 小时前
一文学习 Spring AOP 源码全过程
java·学习·spring
Nyarlathotep011312 小时前
ThreadLocal
java·后端
先积累问题,再逐次解决12 小时前
快速幂优美算法
算法
XiYang-DING12 小时前
【LeetCode】 225.用队列实现栈
算法·leetcode·职场和发展
菜鸟小九13 小时前
JUC(入门1-3章)
java·juc