leetcode刷题60.字符串相加——Java版

Posted 一条coding

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode刷题60.字符串相加——Java版相关的知识,希望对你有一定的参考价值。

⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐

这题目有个鸡儿意思?请计算1+1=2,注意,你不能使用数学!

——leetcode此题热评

前言

哈喽,大家好,我是一条。

糊涂算法,难得糊涂

《糊涂算法》专栏上线倒计时——7天

Question

415. 字符串相加

难度:简单

给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和并同样以字符串形式返回。

你不能使用任何內建的用于处理大整数的库(比如 BigInteger), 也不能直接将输入的字符串转换为整数形式。

示例 1:

输入:num1 = "11", num2 = "123"
输出:"134"

示例 2:

输入:num1 = "456", num2 = "77"
输出:"533"

示例 3:

输入:num1 = "0", num2 = "0"
输出:"0"

Solution

模拟人工加法解决大数加法问题

  • 从后往前按位相加
  • 记录结果和进位
  • 利用StringBuilder拼接结果

Code

所有leetcode代码已同步至github

欢迎star

/**
 * @author 一条coding
 */
class Solution {
    public String addStrings(String num1, String num2) {
        StringBuilder res = new StringBuilder("");
        int i = num1.length() - 1, j = num2.length() - 1, carry = 0;
        while(i >= 0 || j >= 0){
            int n1 = i >= 0 ? num1.charAt(i) - '0' : 0;
            int n2 = j >= 0 ? num2.charAt(j) - '0' : 0;
            int tmp = n1 + n2 + carry;
            carry = tmp / 10;
            res.append(tmp % 10);
            i--; j--;
        }
        if(carry == 1) res.append(1);
        return res.reverse().toString();
    }
}

Result

复杂度分析

  • 时间复杂度:O(M+N)

🌈寻宝

⭐今天是坚持刷题更文的第52/100天

⭐各位的点赞、关注、收藏、评论、订阅就是一条创作的最大动力

⭐更多算法题欢迎关注专栏《leetcode》

为了回馈各位粉丝,礼尚往来,给大家准备了一些算法教学视频和电子书

需要的小伙伴可以点这里

以上是关于leetcode刷题60.字符串相加——Java版的主要内容,如果未能解决你的问题,请参考以下文章

Leetcode刷题100天—2. 两数相加( 链表)—day60

LeetCode Java刷题笔记—445. 两数相加 II

leetcode刷题69.分割平衡字符串——Java版

leetcode刷题45. 同构字符串——Java版

LeetCode Java刷题笔记—2. 两数相加

LeetCode刷题笔记-数据结构-day6