LeetCode 461. 汉明距离

LeetCode 461. 汉明距离

两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。

给你两个整数 x 和 y,计算并返回它们之间的汉明距离。

示例 1:

输入:x = 1, y = 4

输出:2

解释:

1 (0 0 0 1)

4 (0 1 0 0)

↑ ↑

上面的箭头指出了对应二进制位不同的位置。

示例 2:

输入:x = 3, y = 1

输出:1

提示:

0 <= x, y <= 231 - 1

python 复制代码
class Solution:
    def hammingDistance(self, x: int, y: int) -> int:
        res = 0
        for i in range(32):
            res += ((x ^ y) >> i) & 1
        return res

Brian Kernighan 算法,重要常数项优化方法

f(x)=x & (x−1),则 f(x)的值为x二进制中最右侧1变为0的新二进制数的值

BK算法可以用于快速计算二进制数中1的数量,节约常数时间

python 复制代码
class Solution:
    def hammingDistance(self, x: int, y: int) -> int:
        res = 0
        a = x ^ y
        while a:
            a = a & (a - 1)
            res += 1
        return res
相关推荐
猫老师爱编程2 分钟前
【C/C++】【基础数论】33、算数基本定理
人工智能·算法
蒜蓉大猩猩3 分钟前
数据科学 - 字符文本处理
python·算法·机器学习·自然语言处理·numpy
Mar_mxs5 分钟前
算法葫芦书(笔试面试)
人工智能·算法·自然语言处理
SEU-WYL6 分钟前
基于深度学习的图像修复算法
人工智能·深度学习·算法
大柏怎么被偷了8 分钟前
【C++算法】哈希表
算法
十雾九晴丶18 分钟前
buuctf [ACTF2020 新生赛]Include
笔记·算法·学习方法
羚通科技33 分钟前
人员个体检测、PID行人检测、行人检测算法样本
大数据·人工智能·算法·计算机视觉·音视频
专心搞代码1 小时前
排序----希尔排序
数据结构·算法·排序算法
张焚雪1 小时前
关于神经网络的一个介绍
人工智能·深度学习·神经网络·算法·机器学习
AutoAutoJack1 小时前
C# 委托(Delegate)二
开发语言·数据结构·算法·架构·c#