大家好,欢迎来到IT知识分享网。
汉明距离
一、题目描述
汉明距离就是两个整数之间对应二进制位不同的位置数目。给定一个两个整数x和y,计算并返回它们之间的汉明距离。
示例1:
输入:x = 1, y = 4
输出:2
解释:
1 (0 0 0 1)
4 (0 1 0 0)
↑ ↑
示例2
输入:x = 3, y = 1
输出:1
二、解题思路
这里可以将不同位数直接转换为将两个整数做位运算后,直接统计结果中1出现的次数即可。
三、解题方法
可以将x和y做位运算,得到结果s,然后统计s中1出现的次数,1出现的次数就是“汉明距离”即这两个整数对应二进制不同的位置的数目。
代码实现:
class Solution {
public int hammingDistance(int x, int y) {
int s = x ^ y;
int res = 0;
while(s !=0){
res += s & 1;
s >>= 1;
}
return res;
}
}
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/30711.html