LC191 位1的个数

一.任务描述:

给定一个正整数 n,编写一个函数,获取一个正整数的二进制形式并返回其二进制表达式中 设置位 的个数(也被称为汉明重量)。

示例 1:

**输入:**n = 11

**输出:**3

解释: 输入的二进制串 1011 中,共有 3 个设置位。

示例 2:

**输入:**n = 128

**输出:**1

解释: 输入的二进制串 10000000 中,共有 1 个设置位。

示例 3:

**输入:**n = 2147483645

**输出:**30

解释: 输入的二进制串 1111111111111111111111111111101 中,共有 30 个设置位。

二.解题思路:

**逐位检查法:**遍历整数的每一位,检查该位是否为1

》时间复杂度:O(k),其中k为整数位数(对于32位整数为O(32))

》空间复杂度:O(1)

三.代码实现:

C

复制代码
int hammingWeight(int n) {
        int ret = 0;
    for (int i = 0; i < 32; i++) {
        if (n & (1u << i)) {
            ret++;
        }
    }
    return ret;
}

四.优化方向:

分治法(并行计算)

C

复制代码
int hammingWeight_parallel(int n) {
    // 第一步:每2位一组,统计1的个数
    // 01 -> 01 (二进制表示1的个数)
    n = (n & 0x55555555) + ((n >> 1) & 0x55555555);
    
    // 第二步:每4位一组,统计1的个数
    n = (n & 0x33333333) + ((n >> 2) & 0x33333333);
    
    // 第三步:每8位一组,统计1的个数
    n = (n & 0x0F0F0F0F) + ((n >> 4) & 0x0F0F0F0F);
    
    // 第四步:每16位一组,统计1的个数
    n = (n & 0x00FF00FF) + ((n >> 8) & 0x00FF00FF);
    
    // 第五步:每32位一组,统计1的个数
    n = (n & 0x0000FFFF) + ((n >> 16) & 0x0000FFFF);
    
    return n;
}

五.总结:

核心技巧:

  • 位运算技巧n & (n-1) 消去最低位的1是核心技巧之一

  • 并行计算:通过分治思想,将统计1的个数分解为多个小问题并行解决

  • 空间换时间:查表法通过预计算结果来加速实际计算

相关推荐
JieE21219 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架