3592、汉明距离
原创
©著作权归作者所有:来自51CTO博客作者FansUnion的原创作品,请联系作者获取转载授权,否则将追究法律责任
两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。
给你两个整数 x 和 y,计算并返回它们之间的汉明距离。
示例 1:
输入:x = 1, y = 4
输出:2
解释:
1 (0 0 0 1)
4 (0 1 0 0)
↑ ↑
上面的箭头指出了对应二进制位不同的位置。
示例 2:
输入:x = 3, y = 1
输出:1
提示:
0 <= x, y <= 231 - 1
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/hamming-distance
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
package cn.fansunion.leecode.computer.binary;
/**
* 461. 汉明距离<br/>
* 两个整数之间的 汉明距离, 指的是这两个数字对应二进制位不同的位置的数目。<br/>
*
* 给你两个整数 x 和 y,计算并返回它们之间的汉明距离。<br/>
* 力扣
*
* @author wen.lei@brgroup.com
*
* 2022-3-9
*/
public class HammingDistance {
/*示例 1:
输入:x = 1, y = 4
输出:2
解释:
1 (0 0 0 1)
4 (0 1 0 0)
↑ ↑
上面的箭头指出了对应二进制位不同的位置。
示例 2:
输入:x = 3, y = 1
输出:1
提示:
0 <= x, y <= 231 - 1*/
/**
* 思路1:整数转二进制,相同位数比较;从低位到高位;如果位数不同,多余的位数直接“不同”<br/>
* 很多题目,都有类似问题:取2个数字-字符串的最大最小长度,同位的2个数字或字符进行某种操作:相加,相减,比较等<br/>
* 第1次按照这个思路比较,“高位低位”搞错了,因此,换种办法 <br/>
* 思路2:int->str,位数不足的,高位补0;缺几位,补几个0
*
* @param x
* @param y
* @return
*/
public int hammingDistance(int x, int y) {
// 1->1,4->100,5->101,7->111,16->10000
String xStr = Integer.toBinaryString(x);
String yStr = Integer.toBinaryString(y);
int maxLength = Math.max(xStr.length(), yStr.length());
xStr = makeSameLength(xStr, maxLength);
yStr = makeSameLength(yStr, maxLength);
int dif = 0;
for (int index = 0; index < maxLength; index++) {
char c1 = xStr.charAt(index);
char c2 = yStr.charAt(index);
if (c1 != c2) {
dif++;
}
}
return dif;
}
private String makeSameLength(String str, int maxLength) {
if (str.length() == maxLength) {
return str;
}
StringBuilder sb = new StringBuilder();
for (int i = 0; i < maxLength - str.length(); i++) {
sb.append("0");
}
sb.append(str);
return sb.toString();
}
}
//1、100、101、111、10000
public static void main(String[] args) {
System.out.println(Integer.toBinaryString(1));
System.out.println(Integer.toBinaryString(4));
System.out.println(Integer.toBinaryString(14));
System.out.println(Integer.toBinaryString(5));
System.out.println(Integer.toBinaryString(7));
System.out.println(Integer.toBinaryString(16));
}
}