LeetCode——461. 汉明距离(Java)

题目描述

两个整数之间的汉明距离指的是这两个数字对应二进制位不同的位置的数目。
给出两个整数 x 和 y,计算它们之间的汉明距离

示例:
输入: x = 1, y = 4
输出: 2
解释:
1   (0 0 0 1)
4   (0 1 0 0)
       ↑   ↑
上面的箭头指出了对应二进制位不同的位置。

题解思路

返回两个数字二进制下不同的位置的个数,不做这道题我都不知道有内置方法

难道找到二进制中1的个数很常用吗,我反正没怎么用过,以后留个印象

再写个蠢办法,两个数字异或之后遍历找1的个数,代码如下

正确代码

    //内置方法
    public int hammingDistance01(int x, int y) {
        return Integer.bitCount(x ^ y);
    }

    //迭代查找法
    public int hammingDistance02(int x, int y) {
        int z = x ^ y, res = 0;
        while (z != 0) {
            res += z & 1;
            z >>= 1;
        }
        return res;
    }

总结

汉明距离,这真的有这个类型的题目,不过原版好像是字符串中对应位置不同字符的个数

在看内置方法源码的时候,看到了 '>>>' 这个符号,这是无符号数移位,默认用0补充

文章如果存在问题或者有其他更好的题解,欢迎在评论区斧正和评论,各自努力,你我最高处见
posted @ 2021-05-27 21:12  21岁还不是架构师  阅读(133)  评论(0编辑  收藏  举报