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;
}
相关推荐
小欣加油8 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly8 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕9 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei9 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld10 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi811 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang12 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby13 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠14 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力14 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试