Hamming Distance位运算基础问题--力扣101算法题解笔记

10.2Hamming Distance位运算基础问题

题目描述

给定两个十进制数字,求他们二进制表示的汉明距离(Hamming Distance, 即不同位的个数)

输入输出样例

Input :x = 1, y = 4;

Output:2

在这个样例中,1的二进制是0001,4的二进制是0100,一共有两位不同

题解

进行按位异或操作,统计有多少个1

cpp 复制代码
#include <iostream>
using namespace std;

// 汉明距离:两个数字二进制 对应位不同 的数量
int hammingDistance(int x, int y) {
    //  第一步:异或运算 x ^ y
    // 规则:相同为0,不同为1
    // 例子:x=1(0001), y=4(0100)
    // 异或结果:0101 → 十进制 5
    int diff = x ^ y;

    int ans = 0;  // 统计 1 的个数(即不同位的数量)

    //  第二步:循环检查每一位是不是 1
    // 当 diff 不为0时,继续检查
    while (diff) {
        //  第三步:diff & 1 → 取**最后一位**
        //  与运算,两个都为 1 → 结果才是 1
        // 如果最后一位是1,ans+1;是0则+0
        ans += diff & 1;

        //  第四步:右移1位 → 把已经检查过的最后一位扔掉
        // 等价于:diff = diff / 2
        diff >>= 1;
    }

    // 最终 ans 就是二进制不同位的数量
    return ans;
}

int main() {
        int x = 1, y = 4;

        cout << hammingDistance(x, y) << endl;

        return 0;
}
相关推荐
Old Uncle Tom5 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆5 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移5 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业6 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业8 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5489 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove9 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊9 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
code_pgf10 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃11 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划