leetcode 415.字符串相加

⭐️ 题目描述

🌟 leetcode链接:https://leetcode.cn/problems/add-strings/description/

ps: 从两个字符串的末尾开始遍历,依次相加,若大于等于 10 则使用一个变量记录进位,遍历的时候若两个字符串其中一个结束,那么结束的字符串的当前位就用 0 来与另一个字符串相加。这里可以使用头插但是头插需要挪动数据,效率比较低,时间复杂度是 O ( N 2 ) O(N^2) O(N2),所以可以使用尾插,最后逆置即可,这种思路的时间复杂度为 O ( N ) O(N) O(N)。

还有一种特殊的情况是:5 + 5 = 10 两个字符串只有一个数,而且两个字符串的 val 相加后是同时都为结束,但是进位还有一个 1 所以还要判断这种特殊情况。

代码:

cpp 复制代码
class Solution {
public:
    string addStrings(string num1, string num2) {
        // 从两个字符串的末尾 依次相加 进位
        int end1 = num1.size() - 1;
        int end2 = num2.size() - 1;
        string ans;
        // 记录进位
        int unit = 0;
        while (end1 >= 0 || end2 >= 0) {
            // 若当前任意一个字符串结束 那么默认为0
            int val1 = end1 >= 0 ? num1[end1] - '0' : 0;
            int val2 = end2 >= 0 ? num2[end2] - '0' : 0;
            // 尾插
            ans += (val1 + val2 + unit) % 10 + '0';
            // 大于10进位
            unit = val1 + val2 + unit >= 10 ? 1 : 0;

            end1--;
            end2--;
        }

        // 特殊情况:进位还存在
        if (unit) {
            ans += '1';
        }

        // 逆置 传迭代区间 左闭右开
        reverse(ans.begin() , ans.end());

        return ans;
    }
};

相关推荐
xiaoye-duck几秒前
【C++:C++11】核心特性实战:详解C++11列表初始化、右值引用与移动语义
开发语言·c++·c++11
睡一觉就好了。8 分钟前
二叉搜索树
c++
whitelbwwww16 分钟前
C++进阶--类和模板
c++
今天又在学代码写BUG口牙22 分钟前
MFC 定时器轮询实现按住按钮进度条增加(鼠标悬停/长按检测)
c++·mfc·定时器·鼠标·轮询·长按事件
AIminminHu1 小时前
OpenGL渲染与几何内核那点事-项目实践理论补充(三-1-(3):番外篇-当你的CAD打开“怪兽级”STL时:从内存爆炸到零拷贝的极致优化)
开发语言·c++·线程·多线程
嘻嘻哈哈樱桃1 小时前
俄罗斯套娃信封问题力扣--354
算法·leetcode·职场和发展
田梓燊1 小时前
2026/4/12 leetcode 1320
算法·leetcode·职场和发展
j_xxx404_1 小时前
力扣题型--链表(两数相加|两两交换链表中的节点|重排链表)
数据结构·c++·算法·leetcode·蓝桥杯·排序算法
kyle~1 小时前
FANUC 机械臂 --- 配置字
网络·c++·机器人·ros2
oldmao_20001 小时前
第八章 设计并发代码
开发语言·c++·多线程编程·并发编程