【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
}
相关推荐
丁浩6663 小时前
Python机器学习---2.算法:逻辑回归
python·算法·机器学习
伏小白白白3 小时前
【论文精度-2】求解车辆路径问题的神经组合优化算法:综合展望(Yubin Xiao,2025)
人工智能·算法·机器学习
无敌最俊朗@4 小时前
数组-力扣hot56-合并区间
数据结构·算法·leetcode
囚生CY4 小时前
【速写】优化的深度与广度(Adam & Moun)
人工智能·python·算法
码农多耕地呗4 小时前
力扣94.二叉树的中序遍历(递归and迭代法)(java)
数据结构·算法·leetcode
微笑尅乐5 小时前
BFS 与 DFS——力扣102.二叉树的层序遍历
leetcode·深度优先·宽度优先
懒羊羊不懒@5 小时前
Java基础语法—最小单位、及注释
java·c语言·开发语言·数据结构·学习·算法
白云千载尽6 小时前
leetcode 912.排序数组
算法·leetcode·职场和发展
哆啦刘小洋6 小时前
Tips:预封装约束的状态定义
算法
代码充电宝6 小时前
LeetCode 算法题【简单】290. 单词规律
java·算法·leetcode·职场和发展·哈希表