https://www.cnblogs.com/socrates-lzstu/p/6774682.html
转载自此博客,感谢博主的分享!
昨天面试遇到的,挂了,今天自己网上查了一下,理解下怎么实现的,写成博客也不至于过两个月就忘了,也是算给自己一个警醒。
题大概是这样的:
有两个字符串数字,数字特别大,数字超出了Integer相加的范围,类似于
String a1 = “1615146841218….1234”;
String a2 = “8675446841218….4321”;
直接相加的会有溢出,写一个算法实现相加:
我们直接计算是不行的,需要每一位字符一个一个相加,相加之后在一位一位添加到一个新字符串中,但是如果说两个大于5的数值相加,就会溢出一位,相应的上一位就应该加1,所以说我们需要将两个字符串反转,从小到大一个一个的加,溢出之后,在进位上加1。
假设这个字符串是99999和123,倒序排序之后为99999,321,将小的字符串长度补齐, 为99999,32100,第一次遍历, 9 + 3 为12 ,即个位数为2 ,十位数进一位,我们就需要将1 提出来,在下一次遍历时加上,即现在新字符串值为2,进一位有个1;第二次遍历,9+2 = 11,新字符串值为‘2 ’+ ‘(1 + 1)’,又有一个进位1…依此类推
StringBuffer s1 = new StringBuffer(str1).reverse();
StringBuffer s2 = new StringBuffer(str2).reverse();
StringBuffer res = new StringBuffer();
int len1 = s1.length();
int len2 = s2.length();
int len;
if (len1 < len2) {
len = len2;
int count = len2 - len1;
while (count-- > 0)
s1.append('0');
} else {
len = len1;
int count = len1 - len2;
while (count-- > 0)
s2.append('0');
}
int overflow = 0;
int num;
for (int i = 0; i < len; i++) {
num = s1.charAt(i) - '0' + s2.charAt(i) - '0' + overflow;
if (num >= 10) {
overflow = 1;
num -= 10;
} else {
overflow = 0;
}
res.append(String.valueOf(num));
}
if (overflow == 1)
res.append(1);
return res.reverse().toString();
这个算法的时间复杂度是O(n),空间复杂度是O(1),还有可以使用BigInteger类直接计算。