【LeetCode每日一题】461. 汉明距离

该篇博客探讨了如何利用异或运算计算两个整数之间的汉明距离,即二进制表示下不同位的个数。通过转换问题,将求汉明距离转化为计算异或结果中1的个数,并提供了利用低bit技巧高效实现的方法。此外,还提及了其他LeetCode每日一题,如二分查找、二叉搜索树的操作等。
摘要由CSDN通过智能技术生成

【LeetCode每日一题】461. 汉明距离

题目:

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

给出两个整数 x 和 y,计算它们之间的汉明距离。

注意:0 ≤ x, y < 231.

示例:

输入: x = 1, y = 4

输出: 2

解释: 1   (0 0 0 1) 4   (0 1 0 0) ↑   ↑

上面的箭头指出了对应二进制位不同的位置。

题解:

换个角度思考,问题转换为求异或结果值当中1的个数,进一步转换为求二进制中1的个数。

class Solution {
public:
    int lowbit(int x) {
        return x & (-x);
    }
    int hammingDistance(int x, int y) {
        int ret = x ^ y;
        int ans = 0;
        while (ret) {
            ret -= lowbit(ret);
            ans++;
        }
        return ans;
    }
};

本节已完

往日题目:

刷穿二分之二分查找模板

【LeetCode每日一题】938. 二叉搜索树的范围和

【LeetCode每日一题】1482. 制作 m 束花所需的最少天数

【LeetCode每日一题】1723. 完成所有工作的最短时间

【LeetCode每日一题】 1720. 解码异或后的数组

【LeetCode每日一题】1190. 反转每对括号间的子串

【LeetCode每日一题】1787. 使所有区间的异或结果为零

【LeetCode每日一题】664. 奇怪的打印机

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值