mirror of
https://github.com/TheAlgorithms/Java.git
synced 2025-07-27 22:43:30 +08:00
Add Ones & Twos Complement in BitManipulation (#5604)
This commit is contained in:
@ -0,0 +1,47 @@
|
||||
package com.thealgorithms.bitmanipulation;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
/**
|
||||
* Test case for Highest Set Bit
|
||||
* @author Abhinay Verma(https://github.com/Monk-AbhinayVerma)
|
||||
*/
|
||||
public class OnesComplementTest {
|
||||
|
||||
@Test
|
||||
public void testOnesComplementAllZeroes() {
|
||||
|
||||
// Test cases with all-zero binary strings
|
||||
assertEquals("1111", OnesComplement.onesComplement("0000"));
|
||||
assertEquals("111", OnesComplement.onesComplement("000"));
|
||||
assertEquals("11", OnesComplement.onesComplement("00"));
|
||||
assertEquals("1", OnesComplement.onesComplement("0"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testOnesComplementAllOnes() {
|
||||
// Test cases with all-one binary strings
|
||||
assertEquals("0000", OnesComplement.onesComplement("1111"));
|
||||
assertEquals("000", OnesComplement.onesComplement("111"));
|
||||
assertEquals("00", OnesComplement.onesComplement("11"));
|
||||
assertEquals("0", OnesComplement.onesComplement("1"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testOnesComplementMixedBits() {
|
||||
// Test more mixed binary patterns
|
||||
assertEquals("1010", OnesComplement.onesComplement("0101"));
|
||||
assertEquals("0101", OnesComplement.onesComplement("1010"));
|
||||
assertEquals("1100", OnesComplement.onesComplement("0011"));
|
||||
assertEquals("0011", OnesComplement.onesComplement("1100"));
|
||||
assertEquals("1001", OnesComplement.onesComplement("0110"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testOnesComplementEmptyString() {
|
||||
// Test empty string scenario
|
||||
assertEquals("", OnesComplement.onesComplement(""));
|
||||
}
|
||||
}
|
@ -0,0 +1,54 @@
|
||||
package com.thealgorithms.bitmanipulation;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
/**
|
||||
* Test case for Highest Set Bit
|
||||
* @author Abhinay Verma(https://github.com/Monk-AbhinayVerma)
|
||||
*/
|
||||
public class TwosComplementTest {
|
||||
|
||||
@Test
|
||||
public void testTwosComplementAllZeroes() {
|
||||
// Test with a binary number consisting entirely of zeroes
|
||||
assertEquals("10000", TwosComplement.twosComplement("0000"));
|
||||
assertEquals("1000", TwosComplement.twosComplement("000"));
|
||||
assertEquals("100", TwosComplement.twosComplement("00"));
|
||||
assertEquals("10", TwosComplement.twosComplement("0"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testTwosComplementAllOnes() {
|
||||
// Test with a binary number consisting entirely of ones
|
||||
assertEquals("00001", TwosComplement.twosComplement("11111"));
|
||||
assertEquals("0001", TwosComplement.twosComplement("1111"));
|
||||
assertEquals("001", TwosComplement.twosComplement("111"));
|
||||
assertEquals("01", TwosComplement.twosComplement("11"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testTwosComplementMixedBits() {
|
||||
// Test with binary numbers with mixed bits
|
||||
assertEquals("1111", TwosComplement.twosComplement("0001")); // 1's complement: 1110, then add 1: 1111
|
||||
assertEquals("1001", TwosComplement.twosComplement("0111")); // 1's complement: 1000
|
||||
assertEquals("11001", TwosComplement.twosComplement("00111")); // 1's complement: 11000, add 1: 11001
|
||||
assertEquals("011", TwosComplement.twosComplement("101")); // 1's complement: 010, add 1: 011
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testTwosComplementSingleBit() {
|
||||
// Test with single bit
|
||||
assertEquals("10", TwosComplement.twosComplement("0"));
|
||||
assertEquals("1", TwosComplement.twosComplement("1"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testTwosComplementWithLeadingZeroes() {
|
||||
// Test with leading zeroes in the input
|
||||
assertEquals("1111", TwosComplement.twosComplement("0001"));
|
||||
assertEquals("101", TwosComplement.twosComplement("011"));
|
||||
assertEquals("110", TwosComplement.twosComplement("010"));
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user