【刷题笔记10.6】LeetCode:汉明距离

LeetCode:汉明距离

一、题目描述

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

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

二、分析及代码实现

对于汉明距离问题我们其实可以将其转换为:计算x 和 y按位异或后求结果中1 的位数

本题这里我们给出两种解题方法:

方法1:内置位计数功能

java 复制代码
class Solution {
    public int hammingDistance(int x, int y) {
        return Integer.bitCount(x ^ y);
    }
}

方法2:移位实现位计算

算法核心思想如下:

  • 1、首先计算出x 按位异或 y,记作s = x ^ y;并新建计数器result用于记录s的二进制表示中1的位数
  • 2、通过s 按位与 1 不断的检查 s的最低位,如果最低位为 1 ,那么令计数器加 1,然后我们令 s 的整体位右移 1 位,这样最低位就被舍弃,原本的次位变成了最低位。我们重复这个过程直到 s = 0 为止。这样计数器中就累计了 s 的二进制表示中1的数量。

上代码:

java 复制代码
public int hammingDistance(int x, int y) {
        int s = x ^ y;
        int result = 0;
        while (s != 0) {
            result += s & 1; //s按位与1(按位与&:如果两个相应的二进制都为1,则该位的结果为1,否则为0)
            s = s >> 1;  //s二进制整体右移1位
        }
        return result;
    }
相关推荐
lpfasd1231 小时前
两个美国:精英的知识崇拜与底层的反智驯化
笔记
清水迎朝阳1 小时前
解锁读书新体验--有声小说书屋 本地网站的 标注笔记功能
笔记·电子书·读书·标注·有声小说
啊森要自信2 小时前
CANN ops-cv:AI 硬件端视觉算法推理训练的算子性能调优与实战应用详解
人工智能·算法·cann
仟濹2 小时前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事2 小时前
简单模板笔记
数据结构·笔记·算法
YuTaoShao2 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头2 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa2 小时前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior2 小时前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Σίσυφος19003 小时前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面