Add Ones & Twos Complement in BitManipulation (#5604)

This commit is contained in:
Abhinay Verma
2024-10-10 01:15:15 +05:30
committed by GitHub
parent 6e6028e3d0
commit f170078b8b
4 changed files with 170 additions and 0 deletions

View File

@@ -0,0 +1,28 @@
package com.thealgorithms.bitmanipulation;
/**
* @author - https://github.com/Monk-AbhinayVerma
* @Wikipedia - https://en.wikipedia.org/wiki/Ones%27_complement
* The class OnesComplement computes the complement of binary number
* and returns
* the complemented binary string.
* @return the complimented binary string
*/
public final class OnesComplement {
private OnesComplement() {
}
// Function to get the 1's complement of a binary number
public static String onesComplement(String binary) {
StringBuilder complement = new StringBuilder();
// Invert each bit to get the 1's complement
for (int i = 0; i < binary.length(); i++) {
if (binary.charAt(i) == '0') {
complement.append('1');
} else {
complement.append('0');
}
}
return complement.toString();
}
}