快手/字节 CodeTop LeetCode 415.字符串相加

思路:模拟人工加法。

一、算法流程:设定i,j两指针分别指向num1、num2尾部,模拟人工加法。

1.计算进位:计算carry = tmp / 10,代表当前位相加是否产生进位;

2.添加当前位:计算tmp = n1 + n2 + carry,并将当前位tmp % 10,添加至res头部;

3.索引溢出处理:当指针i或j走过数字首部后,给n1、n2赋值为0,相当于给num1、num2中长度较短的数字前面填0,以便后续计算;

4.当遍历完num1、num2后,跳出循环,并根据carry值决定是否在头部添加进位1,最终返回res即可。

二、复杂度分析:

1.时间复杂度:O(max(M,N)),其中M和N为两个数字的长度,按位遍历一遍数字(以较长的数字为准)。

2.空间复杂度:O(1),指针与变量需要使用常数大小的空间。

注意:

(1)字符串相加是对应位相加,因此i和j是从字符串最后一位做完运算后,i--,j--。

(2)字符串相乘是每位都要和对方的所有位相乘,因此是

for(int i = num1.length() - 1;i >= 0;i--){

int val1 =

for(int j = num2.length() - 1;j >= 0;j--){

int val2 =

int sum =

处理当前位和进位

}

}

附代码:

java 复制代码
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 val1 = i >= 0 ? num1.charAt(i) - '0' : 0;
            int val2 = j >= 0 ? num2.charAt(j) - '0' : 0;
            int tmp = val1 + val2 + carry;
            carry = tmp / 10;
            res.append(tmp % 10);
            i--;j--;
        }
        // 处理最高位相加后可能产生的进位
        // 在加法运算中,当两个数字的最高位相加(加上之前的进位)后,如果结果大于等于10,就会产生一个进位
        // 这个进位要在循环结束后单独处理
        if(carry == 1){
            res.append(1);
        }
        return res.reverse().toString();
    }
}

ACM模式:

java 复制代码
import java.util.Scanner;

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 val1 = i >= 0 ? num1.charAt(i) - '0' : 0;
            int val2 = j >= 0 ? num2.charAt(j) - '0' : 0;
            int tmp = val1 + val2 + carry;
            carry = tmp / 10;
            res.append(tmp % 10);
            i--;
            j--;
        }
        if (carry == 1) {
            res.append(1);
        }
        return res.reverse().toString();
    }
}

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        // 读取两个数字字符串
        String num1 = scanner.next();
        String num2 = scanner.next();

        // 计算字符串相加结果
        Solution solution = new Solution();
        String result = solution.addStrings(num1, num2);
        System.out.println(result);

        scanner.close();
    }
}
相关推荐
JieE21217 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架