El siguiente código implementa la adición binaria sin realizar ninguna operación aritmética, binaria o de otro tipo. La "adición" real se realiza por lookupTable
, y todo lo demás es manipulación directa de cadena. Lo escribí con la intención de hacerlo lo más instructivo posible, enfatizando el proceso en lugar de la eficiencia. Espero eso ayude.
public class BinaryArithmetic {
static String[] lookupTable = {
"0+0+0=00",
"0+0+1=01",
"0+1+0=01",
"0+1+1=10",
"1+0+0=01",
"1+0+1=10",
"1+1+0=10",
"1+1+1=11",
};
static String lookup(char b1, char b2, char c) {
String formula = String.format("%c+%c+%c=", b1, b2, c);
for (String s : lookupTable) {
if (s.startsWith(formula)) {
return s.substring(s.indexOf("=") + 1);
}
}
throw new IllegalArgumentException();
}
static String zeroPad(String s, int length) {
while (s.length() < length) {
s = "0" + s;
}
return s;
}
static String add(String s1, String s2) {
int length = Math.max(s1.length(), s2.length());
s1 = zeroPad(s1, length);
s2 = zeroPad(s2, length);
String result = "";
char carry = '0';
for (int i = length - 1; i >= 0; i--) {
String columnResult = lookup(s1.charAt(i), s2.charAt(i), carry);
result = columnResult.charAt(1) + result;
carry = columnResult.charAt(0);
}
if (carry == '1') {
result = carry + result;
}
return result;
}
public static void main(String args[]) {
System.out.println(add("11101", "1001"));
}
}
Mientras estamos en ello, que también podría hacer multiply
también.
static String multiply(String s1, String s2) {
String result = "";
String zeroSuffix = "";
for (int i = s2.length() - 1; i >= 0; i--) {
if (s2.charAt(i) == '1') {
result = add(result, s1 + zeroSuffix);
}
zeroSuffix += "0";
}
return result;
}
¿Desea obtener información sobre cómo implementar el algoritmo real o simplemente realizar operaciones aritméticas con estas cadenas? – Daff
http://stackoverflow.com/questions/1218149/arbitrary-precision-arithmetic-explanation – paxdiablo
Daff, me gustaría aprender cómo implementar el algoritmo. –