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的个数分解为多个小问题并行解决

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

相关推荐
那雨倾城2 分钟前
用 YOLO Pose + Segmentation 在PiscCode构建“语义佛光”:一次实时视觉语义融合实验
图像处理·python·opencv·算法·yolo·计算机视觉·视觉检测
nnerddboy3 分钟前
解决传统特征波段选择的局限性:1.对偶学习
学习·算法·机器学习
CoovallyAIHub11 分钟前
自顶向下 or 自底向上?姿态估计技术是如何进化的?
深度学习·算法·计算机视觉
q_302381955621 分钟前
14.7MB轻量模型!NVIDIA Jetson边缘设备解锁工厂设备故障预警新方案
人工智能·python·算法·ascend·算子开发
爱敲点代码的小哥29 分钟前
C#哈希表遍历技巧全解析以及栈 堆 队列的认识
算法·哈希算法
xiaoxue..31 分钟前
爬楼梯问题:从递归到动态规划再到闭包的进化之路
javascript·算法·面试·动态规划
CoovallyAIHub34 分钟前
YOLO11算法深度解析:四大工业场景实战,开源数据集助力AI质检落地
深度学习·算法·计算机视觉
import_random39 分钟前
[推荐]embedding嵌入表示是如何生成的(实战)
算法
chao18984441 分钟前
基于布谷鸟搜索算法的分布式电源多目标选址定容
算法
Xの哲學42 分钟前
Linux IPsec 深度解析: 架构, 原理与实战指南
linux·服务器·网络·算法·边缘计算