美文网首页剑指offer算法系列——Swift版本
剑指offer—面试题15:二进制中1的个数

剑指offer—面试题15:二进制中1的个数

作者: FY_Chao | 来源:发表于2020-12-25 14:29 被阅读0次

    请实现一个函数,输入一个整数(以二进制串形式),输出该数二进制表示中 1 的个数。例如,把 9 表示成二进制是 1001,有 2 位是 1。因此,如果输入 9,则该函数输出 2。

    根据位运算的方式, 0 或者 1 & 1得到的结果和原来的数一致,我们可以通过不断的左移数字n,根据最右位上 & 1,判断是否是1。

    右移n算法:

        func hammingWeight(_ n: Int) -> Int {
            var n = n
            var res = 0
            while n != 0 {
                if n & 1 == 1 {
                    res += 1
                }
                n = n >> 1
            }
            return res
        }
    

    算法二: n&(n-1)

    • (n−1) : 二进制数字 n 最右边的数如果是 1 则变成 0,其它不变 。如果是0,则 n 最右边的1的变成0,1 右边的 0 都变成 1 。1001 - 1 = 1000, 1100 - 1 = 1011。
    • n&(n−1) : 二进制数字 n 最右边的 1 变成 0 ,其余不变。1001 & 1000 = 1000,1100 & 1011 = 1000。
        func hammingWeight(_ n: Int) -> Int{
            var n = n
            var res = 0
            while n != 0{
                    res += 1
                    n &= n - 1
            }
                return res
        }
    

    算法的时间复杂度: O(M),其中M表示二进制数字 n 中 1 的个数,则需循环 M 次(每轮消去一个 1 )。

    相关文章

      网友评论

        本文标题:剑指offer—面试题15:二进制中1的个数

        本文链接:https://www.haomeiwen.com/subject/qdubnktx.html