题目描述
给定两个字符串形式的非负整数 num1 和 num2 ,计算它们的和。
提示:
- num1 和 num2 的长度都小于 5100
- num1 和 num2 都只包含数字 0-9
- num1 和 num2 都不包含任何前导零
- 你不能使用任何內建 BigInteger 库,也不能直接将输入的字符串转换为整数形式
题解
我们只需要对两个大整数模拟「竖式加法」的过程。竖式加法就是我们平常学习生活中常用地对两个整数相加的方法,回想一下我们在纸上对两个整数相加的操作,是不是如下图将相同数位对齐,从低到高逐位相加,如果当前位和超过 10,则向高位进一位?因此我们只要将这个过程用代码写出来即可。我们使用两个变量分别指向两个数的末尾,进行加法操作,同时使用 carry 保存进位,若两个字符串不一样长,我们两个字符串遍历完成后,要继续遍历未计算的字符串,最后,别忘了,如果进位是 1 的话,要把进位加到最终的结果中。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
| public String addStrings(String num1, String num2) { int index1 = num1.length() - 1; int index2 = num2.length() - 1; StringBuilder res = new StringBuilder(); int carry = 0; while (index1 >=0 && index2 >= 0) { int n1 = num1.charAt(index1) - '0'; int n2 = num2.charAt(index2) - '0'; carry = addNum(n1, n2, carry, res); index1--; index2--; }
while (index1 >= 0) { int n1 = num1.charAt(index1) - '0'; carry = addNum(n1, 0, carry, res); index1--; }
while (index2 >= 0) { int n2 = num2.charAt(index2) - '0'; carry = addNum(0, n2, carry, res); index2--; }
if (carry > 0) { res.append(carry); } return res.reverse().toString(); }
public int addNum(int n1, int n2, int carry, StringBuilder res) { int sum = n1 + n2 + carry; res.append(sum % 10); return sum / 10; }
|
这里,我们其实不需要这么长的代码,判断最后哪个字符串更长,针对短的字符串,我们进行补 0 操作即可。也不需要判断是否有进位,最后还要记得加上去。我们可以简化代码如下。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| public String addStrings(String num1, String num2) { int index1 = num1.length() - 1; int index2 = num2.length() - 1; int carry = 0; StringBuilder res = new StringBuilder(); while (index1 >= 0 || index2 >= 0 || carry != 0) { int x = index1 >= 0 ? num1.charAt(index1) - '0' : 0; int y = index2 >= 0 ? num2.charAt(index2) - '0' : 0; int sum = x + y + carry; res.append(sum % 10); carry = sum / 10; index1--; index2--; } return res.reverse().toString(); }
|
复杂度分析
- 时间复杂度:Ο(max(m, n)),其中 m 和 n 分别是两个字符串的长度。竖式加法的次数取决于较大数的位数。
- 空间复杂度:O(n)。除答案外我们只需要常数空间存放若干的变量。但是解法中使用到了 StringBuilder,空间复杂度为 O(n)。
来源
字符串相加 | 力扣(LeetCode)
字符串相加 | 题解(LeetCode)
文章标题:字符串相加
文章作者:cylong
文章链接:https://0skyu.cn/p/53ac.html
有问题或者建议欢迎在下方评论。欢迎转载、引用,但希望标明出处,感激不尽(●’◡’●)