【LeetCode】191. 位1的个数

题目链接:191. 位1的个数

题目描述:

解法1 :题意很简单就不说了,这里先说一种最简单的解法,首先我们知道一点:n&(n-1)相当于把是将n的二进制位中最低位的1变为了0,其它位保持不变,因此可以利用这个特性进行解答。

代码:

go 复制代码
func hammingWeight(n int) int {
    res := 0
    for ; n > 0; n &= (n-1) {
        res++
    }
    return res
}

解法2 :也很简单的思路,就是直接计算这个数的二进制位中1的个数,不过不是先求出所有二进制位再来计算,而是通过位移动的方式。题目区间中很明显一点就是这个数是个32位的,因此我们最多会移动32次来检查结果,并且我们知道,要检查一个数的二进制位中某位为1,我们只需要将这个数和2的幂次方结合进行 位与运算即可,因此这里我们可以先不移动这个数本身,借助这个2的幂次方来进行检查,看这个数有多少位二进制是1。

go 复制代码
func hammingWeight(n int) int {
    res := 0
    for i:=0; i <= 31; i++ {
        if (1 << i & n) > 0 {
            res++
        }
    }
    return res
}

其次,我们也可以直接将这个数进行移动,然后与1做位与运算看结果即可,最多移动31次。

go 复制代码
func hammingWeight(n int) int {
    res := 0
    for i:=0; i <= 31; i++ {
        if 1 & int(n>>i) == 1 {
            res++
        }
    }
    return res
}
相关推荐
卷福同学5 小时前
QClaw内测体验,能用微信指挥AI干活了
人工智能·算法·ai编程
sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章34-投影向量
图像处理·人工智能·opencv·算法·计算机视觉
xiaoye-duck5 小时前
《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂
数据结构·c++·算法·递归
Eward-an5 小时前
【算法竞赛/大厂面试】盛最多水容器的最大面积解析
python·算法·leetcode·面试·职场和发展
山栀shanzhi5 小时前
归并排序(Merge Sort)原理与实现
数据结构·c++·算法·排序算法
阿豪学编程5 小时前
LeetCode438: 字符串中所有字母异位词
算法·leetcode
Trouvaille ~5 小时前
【递归、搜索与回溯】专题(七):FloodFill 算法——勇往直前的洪水灌溉
c++·算法·leetcode·青少年编程·面试·蓝桥杯·递归搜索回溯
地平线开发者5 小时前
征程 6P codec decoder sample
算法·自动驾驶
地平线开发者6 小时前
征程 6X Camera 接入数据评估
算法·自动驾驶
Storynone6 小时前
【Day23】LeetCode:455. 分发饼干,376. 摆动序列,53. 最大子序和
python·算法·leetcode