算法(TS):汉明距离

两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。给你两个整数 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 <= 2^31 - 1

解法一

利用十进制与二进制的转换关系,将x和y都与2求模,如果得到值相同,则将距离加1,同时将x和y都整体右移一位继续求模,直到x和y都不大于1

typescript 复制代码
function hammingDistance(x: number, y: number): number {
    let distance: number = 0

    while(x>0||y>0) {
        if(x%2!==y%2) {
            distance++
        }
        x=x>>>1
        y=y>>>1
    }
    return distance
};

有逻辑运算符代替求模

typescript 复制代码
function hammingDistance(x: number, y: number): number {
    let distance: number = 0

    while(x>0||y>0) {
        if((x&1)!==(y&1)) {
            distance++
        }
        x=x>>>1
        y=y>>>1
    }
    return distance
};

解法二

将x和y先异或,异或的原理是当且仅当输入位不同时输出为 1,计算 x^y 中 1 的个数

typescript 复制代码
function hammingDistance(x: number, y: number): number {
    let distance: number = 0
    let s = x ^ y
    while(s>0) {
        distance += s & 1
        s = s >>> 1
    }
    return distance
};

时间复杂度:O(log⁡C),其中 C 是元素的数据范围,本题中 C === 31。空间复杂度:O(1)。

相关推荐
CoderYanger1 小时前
动态规划算法-简单多状态dp问题:15.买卖股票的最佳时机含冷冻期
开发语言·算法·leetcode·动态规划·1024程序员节
Xの哲學1 小时前
Linux RTC深度剖析:从硬件原理到驱动实践
linux·服务器·算法·架构·边缘计算
狐571 小时前
2025-12-04-牛客刷题笔记-25_12-4-质数统计
笔记·算法
小O的算法实验室1 小时前
2024年IEEE IOTJ SCI2区TOP,基于混合算法的水下物联网多AUV未知环境全覆盖搜索方法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
洲星河ZXH2 小时前
Java,比较器
java·开发语言·算法
CoderYanger2 小时前
递归、搜索与回溯-FloodFill:33.太平洋大西洋水流问题
java·算法·leetcode·1024程序员节
CodeByV2 小时前
【算法题】双指针(二)
数据结构·算法
点云SLAM3 小时前
Boost库中Math 模块的根搜索 / 根求解和示例
数学·算法·数值优化·根搜索 / 根求解和示例·函数根求解·boost模块
我搞slam3 小时前
EM Planner算法与代码解读
算法