【刷题笔记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;
    }
相关推荐
华山沦贱1 小时前
open62541 V1.5.4版对C++ Builder支持的bug
笔记
梦梦代码精1 小时前
为什么这个开源的AI平台会火?有点东西。。。
人工智能·算法·机器学习·docker·开源
随意起个昵称1 小时前
线性dp-综合刷题1(Not Alone)
算法·动态规划
稷下元歌2 小时前
七天学会plc 加机器视觉完整笔记:S7-1200 数据类型、存储区与寻址方式(I/Q/M/DB 详解)。
网络·数据库·笔记
逸模2 小时前
AI+BIM 重构连锁公装新范式 逸模打造数字化营建核心底座
大数据·人工智能·笔记·其他·信息可视化·重构
如何原谅奋力过但无声2 小时前
【灵神高频面试题合集09-13】二叉树、二叉搜索树
数据结构·算法·leetcode
皆圥忈2 小时前
磁盘物理结构与文件系统基础讲解
linux·算法
数据仓库搬砖人2 小时前
用 LangGraph 从零搭一个客服 Agent:多轮对话 + 工具调用全流程
算法
GuWenyue2 小时前
告别JS类型坑!Ts为什么在ai时代逐渐成为"第一"语言
前端·算法·typescript
子琦啊2 小时前
哈希与前缀和
算法·哈希算法