leetcode415. 字符串相加

一、题目描述

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

你不能使用任何內建的用于处理大整数的库(比如 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

num1 和num2 都只包含数字 0-9

num1 和num2 都不包含任何前导零

二、题目解析

1、双指针法

复制代码
class Solution {
    public String addStrings(String num1, String num2) {
        int i = num1.length() - 1,j = num2.length() - 1,carry = 0;
        StringBuilder builder = new StringBuilder();
        while(i >= 0 || j >= 0 || carry > 0){
            int temp1 = i >= 0 ? num1.charAt(i) - '0' : 0;
            int temp2 = j >= 0 ? num2.charAt(j) - '0' : 0;
            int num = (temp1 + temp2 + carry) % 10;
            carry = (temp1 + temp2 + carry) / 10;
            builder.append(num);
            i--;
            j--;
        }
        return builder.reverse().toString();
    }
}
相关推荐
我材不敲代码7 分钟前
Python 函数核心:位置参数与关键字参数详解
java·前端·python
qq_3331209738 分钟前
C++高并发内存池的整体设计和实现思路_C 语言
java·c语言·c++
mh_f42 分钟前
33.批量通过GET链接下载图片到指定文件夹下
java
金銀銅鐵43 分钟前
[Java] 如何理解 class 文件中方法的 access flags?
java·后端
智研数智工坊44 分钟前
SpringBoot4.0.6 + Security7.x + JWT 最新完整实战|无状态权限认证、统一异常处理、可直接落地
java·spring boot·spring security·jwt·权限认证
DIY源码阁1 小时前
JavaSwing宿舍管理系统 - MySQL版
java·数据库·mysql·eclipse
Han_han9191 小时前
递归相关题目:
java
kTR2hD1qb1 小时前
Claude Code Skill的介绍与使用
java·前端·数据库·人工智能
汤米粥1 小时前
python学习——核心语法三
java·python·学习
basketball6161 小时前
Kadane算法 C++实现
java·c++·算法