package cn.yunmanage.haikang;
public class BigNumberAdd {
public static void main(String[] args) {
System.out.println(bigNumberAdd("111", "999"));
}
public static String bigNumberAdd(String f, String s) {
// 翻转两个字符串,并转换成数组
char[] a = new StringBuffer(f).reverse().toString().toCharArray();
char[] b = new StringBuffer(s).reverse().toString().toCharArray();
int lenA = a.length;
int lenB = b.length;
// 计算两个长字符串中的较长字符串的长度
int len = lenA > lenB ? lenA : lenB;
int[] result = new int[len + 1];// 长度为len+1(由于可能有进位)
for (int i = 0; i
// 若是当前的i超过了其中的一个,就用0代替,和另外一个字符数组中的数字相加
int aint = i
int bint = i
result[i] = aint + bint;
}
// 处理结果集合,若是大于等于10的就向前一位进位,自己进行除10取余
for (int i = 0; i
if (result[i] >= 10) {
result[i + 1] += result[i] / 10;
result[i] %= 10;
}
}
StringBuffer sb = new StringBuffer();
// 该字段用于标识是否有前置0,若是有就不要存储
boolean flag = true;
for (int i = len; i >= 0; i--) {
if (result[i] == 0 && flag) {
continue;
} else {
flag = false;
}
sb.append(result[i]);
}
return sb.toString();
}
}
package cn.yunmanage.haikang;
public class BigNumberSub {
public static void main(String[] args) {
System.out.println(bigNumberSub02("99", "2222"));
}
public static String bigNumberSub(String f, String s) {
System.out.print("减法:" + f + "-" + s + "=");
// 将字符串翻转并转换成字符数组
char[] a = new StringBuffer(f).reverse().toString().toCharArray();
char[] b = new StringBuffer(s).reverse().toString().toCharArray();
int lenA = a.length;
int lenB = b.length;
// 找到最大长度
int len = lenA > lenB ? lenA : lenB;
int[] result = new int[len];
// 表示结果的正负
char sign = '+';
// 判断最终结果的正负
if (lenA
sign = '-';
} else if (lenA == lenB) {
int i = lenA - 1;
while (i > 0 && a[i] == b[i]) {
i--;
}
if (a[i]
sign = '-';
}
}
// 计算结果集,若是最终结果为正,那么就a-b不然的话就b-a
for (int i = 0; i
int aint = i
int bint = i
if (sign == '+') {
result[i] = aint - bint;
} else {
result[i] = bint - aint;
}
}
// 若是结果集合中的某一位小于零,那么就向前一位借一,而后将本位加上10。其实就至关于借位作减法
for (int i = 0; i
if (result[i]
result[i + 1] -= 1;
result[i] += 10;
}
}
StringBuffer sb = new StringBuffer();
// 若是最终结果为负值,就将负号放在最前面,正号则不须要
if (sign == '-') {
sb.append('-');
}
// 判断是否有前置0
boolean flag = true;
for (int i = len - 1; i >= 0; i--) {
if (result[i] == 0 && flag) {
continue;
} else {
flag = false;
}
sb.append(result[i]);
}
// 若是最终结果集合中没有值,就说明是两值相等,最终返回0
if (sb.toString().equals("")) {
sb.append("0");
}
// 返回值
System.out.println(sb.toString());
return sb.toString();
}
}