Skip to content

Commit eec23bb

Browse files
committed
feat: Add HammingDistance new algorithm with Junit tests
1 parent 90d20b3 commit eec23bb

File tree

2 files changed

+34
-0
lines changed

2 files changed

+34
-0
lines changed
Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
package com.thealgorithms.bitmanipulation;
2+
3+
public class HammingDistance {
4+
5+
/**
6+
* Calculates the Hamming distance between two integers.
7+
* The Hamming distance is the number of differing bits between the two integers.
8+
*
9+
* @param x The first integer.
10+
* @param y The second integer.
11+
* @return The Hamming distance (number of differing bits).
12+
*/
13+
public static int hammingDistance(int x, int y) {
14+
int xor = x ^ y;
15+
return Integer.bitCount(xor);
16+
}
17+
}
Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
package com.thealgorithms.bitmanipulation;
2+
3+
import static org.junit.jupiter.api.Assertions.assertEquals;
4+
5+
import org.junit.jupiter.api.Test;
6+
7+
public class HammingDistanceTest {
8+
9+
@Test
10+
public void testHammingDistance() {
11+
assertEquals(3, HammingDistance.hammingDistance(9, 14)); // 1001 vs 1110, Hamming distance is 3
12+
assertEquals(0, HammingDistance.hammingDistance(10, 10)); // Same number, Hamming distance is 0
13+
assertEquals(1, HammingDistance.hammingDistance(1, 0)); // 0001 vs 0000, Hamming distance is 1
14+
assertEquals(2, HammingDistance.hammingDistance(4, 1)); // 100 vs 001, Hamming distance is 2
15+
assertEquals(4, HammingDistance.hammingDistance(0, 15)); // 0000 vs 1111, Hamming distance is 4
16+
}
17+
}

0 commit comments

Comments
 (0)