【LeetCode】191. 位1的个数

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

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

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

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

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

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

相关推荐

  1. 191. 1个数

    2024-04-27 03:52:01       37 阅读
  2. 191. 1个数

    2024-04-27 03:52:01       32 阅读
  3. 191. 1个数

    2024-04-27 03:52:01       13 阅读
  4. 【技巧】Leetcode 191. 1个数【简单】

    2024-04-27 03:52:01       9 阅读
  5. 力扣:191. 1个数(Python3)

    2024-04-27 03:52:01       41 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-27 03:52:01       14 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-27 03:52:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-27 03:52:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-27 03:52:01       18 阅读

热门阅读

  1. 深入探索Python开发:打造高质量技术的实战之路

    2024-04-27 03:52:01       14 阅读
  2. SQL 的三值逻辑 (TRUE/FALSE/UNKNOW。)

    2024-04-27 03:52:01       13 阅读
  3. Nginx高级配置与重写规则详解:从入门到实践

    2024-04-27 03:52:01       14 阅读
  4. Vue2之computed VS methods

    2024-04-27 03:52:01       10 阅读
  5. 为什么 GraphQL 可以取代 Redux?

    2024-04-27 03:52:01       13 阅读
  6. 什么是graphQL

    2024-04-27 03:52:01       10 阅读
  7. 内网pth横向渗透思路笔记

    2024-04-27 03:52:01       12 阅读
  8. vue用法示例(三)

    2024-04-27 03:52:01       10 阅读
  9. [Android]Jetpack Compose自定义主题

    2024-04-27 03:52:01       10 阅读
  10. STM32 JTAG

    2024-04-27 03:52:01       12 阅读
  11. 好用的项目管理系统推荐,项目人必看!

    2024-04-27 03:52:01       11 阅读