给定两个字符串形式的非负整数num1 和 num2, 计算他们的和.
注意:
- num1和num2的长度都小于5100.
- num1和num2的都只包含数字0-9
- num1和num2都不包含前导零
- 你懂得
方法一:模拟
思路与算法
我们只需要对两个大整数模拟[竖式加法], 竖式加法就是我们平常学习生活中对两个整数相加的方法, 回想一下我们在纸上对两个整数相加的过程, 是不是如下图将相同的数位对齐, 从低到高逐位相加,如果当前位和超过10, 则向高位进一位?因此我们只要将这个过程用代码写出来即可.
具体实现也不复杂,我们定义两个指针, i和j分别指向num1和num2 的末尾,即最低位, 同时定义一个变量add 维护当前是否有进位,然后从末尾到开头逐位相加即可, 你可能会想两个数字位数不同怎么处理,这里我们统一在指针当前下标处于负数的时候返回0, 等价于对位数较短的数字进行了补零操作, 这样就可以除去两个数字位数不同的情况的处理, 具体可以看下面的代码.
class Solution {
public:
string addStrings(string num1, string num2) {
int i = num1.length() - 1, j = num2.length() - 1, add = 0;
string ans = "";
while (i >= 0 || j >= 0 || add != 0) {
int x = i >= 0 ? num1[i] - '0' : 0;
int y = j >= 0 ? num2[j] - '0' : 0;
int result = x + y + add;
ans.push_back('0' + result % 10);
add = result / 10;
i -= 1;
j -= 1;
}
// 计算完以后的答案需要翻转过来
reverse(ans.begin(), ans.end());
return ans;
}
};
作者:LeetCode-Solution
链接:https://leetcode-cn.com/problems/add-strings/solution/zi-fu-chuan-xiang-jia-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
复杂度分析:
- 时间复杂度:O(max(len1,len2)), 竖式加法的次数=两个数的最大位数
- 空间复杂度:O(1).除答案外我们需要常数空间存放若干变量. 在Java解法使用到了StringBuffer, 故java解法的空间复杂度为O(n).