leetcode461——Hamming Distance

题目大意:计算两个整数的汉明距离(两个数的二进制位中不同的位置个数)

分析:位运算。计算汉明距离:只要统计两个数的异或中有几个1即可。比如1(0001)和4(0100),异或后(0101)就能显示出有几位不同。异或操作——0^1=1,0^0=0。

方法一:库函数。C++:return bitset<32>(x^y).count();JAVA:return Integer.bitcount(x^y);

方法二:移位。可以将两个数最右位不断&1并右移两个数,也可以将异或不断&1并右移。

方法三:布赖恩·克尼根算法。XOR & (XOR - 1)会将XOR最右的一个1移除。这样可以比逐个移位更快速的统计异或中1的个数。

代码:

方法二:

class Solution {
public:
    int hammingDistance(int x, int y) {
        int dist = 0;
        while(x || y){
            dist += (x & 1) ^ (y & 1);
            x = x >> 1;
            y = y >> 1;
        }
        return dist;
    }
};
class Solution {
public:
    int hammingDistance(int x, int y) {
        int dist = 0;
        int n = x ^ y;
        while(n){
            dist += n & 1;
            n = n >> 1;
        }
        return dist;
    }
};

方法三:

class Solution {
public:
    int hammingDistance(int x, int y) {
        int dist = 0;
        int xor = x ^ y;
        while(xor){
            xor = xor & (xor - 1);
            dist++;
        }
        return dist;
    }
};

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值