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;
}
相关推荐
wanderist.2 分钟前
算法模板-字符串
数据结构·算法·哈希算法
xiaoye-duck3 分钟前
《算法题讲解指南:动态规划算法--子序列问题》--29.最长递增子序列的个数,30.最长数对链,31.最长定差子序列
c++·算法·动态规划
Yzzz-F7 分钟前
Problem - 2180D - Codeforces
算法
moonsea02037 分钟前
2023.9.25
算法
汀、人工智能10 分钟前
[特殊字符] Python基础语法速成教程
算法·链表·均值算法·哈希表·lru缓存·python基础语法速成教程
tankeven14 分钟前
HJ164 太阳系DISCO
c++·算法
来自远方的老作者17 分钟前
第7章 运算符-7.1 算术运算符
开发语言·数据结构·python·算法·算术运算符
white-persist1 小时前
【vulhub weblogic CVE-2017-10271漏洞复现】vulhub weblogic CVE-2017-10271漏洞复现详细解析
java·运维·服务器·网络·数据库·算法·安全
汀、人工智能1 小时前
[特殊字符] 第9课:三数之和
数据结构·算法·数据库架构·图论·bfs·三数之和
汀、人工智能1 小时前
[特殊字符] 第10课:接雨水
数据结构·算法·数据库架构·图论·bfs·接雨水