LeetCode-415.字符串相加

给定两个字符串形式的非负整数num1 和 num2, 计算他们的和.

注意:

  1. num1和num2的长度都小于5100.
  2. num1和num2的都只包含数字0-9
  3. num1和num2都不包含前导零
  4. 你懂得

方法一:模拟

思路与算法

我们只需要对两个大整数模拟[竖式加法], 竖式加法就是我们平常学习生活中对两个整数相加的方法, 回想一下我们在纸上对两个整数相加的过程, 是不是如下图将相同的数位对齐, 从低到高逐位相加,如果当前位和超过10, 则向高位进一位?因此我们只要将这个过程用代码写出来即可.fig1

具体实现也不复杂,我们定义两个指针, 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).
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值