leetcode 415.字符串相加

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

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

示例 1:

复制代码
输入:num1 = "11", num2 = "123"
输出:"134"

示例 2:

复制代码
输入:num1 = "456", num2 = "77"
输出:"533"

示例 3:

复制代码
输入:num1 = "0", num2 = "0"
输出:"0"

提示:

  • 1 <= num1.length, num2.length <= 104

  • num1num2 都只包含数字 0-9

  • num1num2 都不包含任何前导零

    class Solution {
    public String addStrings(String num1, String num2) {
    StringBuilder result = new StringBuilder();
    int i = num1.length() - 1;
    int j = num2.length() - 1;
    int carry = 0;

    复制代码
          while (i >= 0 || j >= 0 || carry != 0) {
              int digit1 = i >= 0 ? num1.charAt(i--) - '0' : 0;
              int digit2 = j >= 0 ? num2.charAt(j--) - '0' : 0;
              int sum = digit1 + digit2 + carry;
              result.append(sum % 10);
              carry = sum / 10;
          }
          
          return result.reverse().toString();
      }

    }

相关推荐
Dontla6 分钟前
Linux怎么查看时区信息?(Linux时区)(tzselect)
linux·运维·服务器
鱼骨不是鱼翅1 小时前
Linux---第三天---权限
linux·运维·服务器
Duan2baka1 小时前
我爱发明之Linux下使用Conky在桌面显示Spotify状态及封面字符画
linux
BenChuat2 小时前
Ubuntu 系统 Docker 启动失败(iptables/nf\_tables)
linux·ubuntu·docker
人工智能训练师2 小时前
华为服务器如何部署Mindie镜像
linux·人工智能·docker
weixin_438077493 小时前
langchain入门笔记02:几个实际应用
服务器·langchain·rag
jingfeng5144 小时前
浅谈对linux进程池的理解
linux·运维·服务器
西阳未落4 小时前
Linux(17)——Linux进程信号(下)
linux·运维·服务器
爱coding的橙子4 小时前
每日算法刷题Day58:8.7:leetcode 单调栈5道题,用时2h
算法·leetcode·职场和发展