LeetCode 415.字符串相加 C++写法

LeetCode 415.字符串相加 C++写法

思路🤔:

首先不能用stoi和tostring来做,如果给一个很大的数那一定存不下。我们可以从后往前一位一位的取 ,创建一个变量存储进位 用于计算下一位数,之后取模得到当前数字 ,每一位尾插在新创建的string中 ,完成所有尾插后用reverse进行逆置就是我们要得到的结果。

代码🔎:

C++ 复制代码
class Solution {
public:
    string addStrings(string num1, string num2) {
        int end1 = num1.size() - 1;
        int end2 = num2.size() - 1;
        int next = 0; //存进位
        string str; //用于存结果
        while(end1 >= 0 || end2 >= 0) //两个字符串都走完才算完成相加
        {
            int x1 = end1 >= 0 ? num1[end1] - '0' : 0; //当一个已经走完了,那么就为0,不再相加
            int x2 = end2 >= 0 ? num2[end2] - '0' : 0;
            int ret = x1 + x2 + next; //计算相加后为多少
            next = ret / 10; //取进位
            ret = ret % 10; //取当前数字用于尾插
            str += ('0' + ret); //尾插
            end1--;
            end2--;
        }
        if (next == 1) //防止出现num1=9,num2=1的情况
            str += '1';
        reverse(str.begin(),str.end()); //逆置
        return str;
    }
};
相关推荐
方便面不加香菜2 分钟前
C++ 类和对象(一)
开发语言·c++
浅念-7 分钟前
C++ STL list 容器
开发语言·数据结构·c++·经验分享·笔记·算法·list
重生之后端学习9 分钟前
39. 组合总和
java·数据结构·算法·职场和发展·深度优先
Frostnova丶11 分钟前
LeetCode 868. 二进制间距
算法·leetcode
nix.gnehc12 分钟前
深入理解Go并发核心:GMP模型与Goroutine底层原理
开发语言·算法·golang
心本无晴.18 分钟前
RAG中的混合检索(Hybrid Search):稀疏检索与稠密检索的强强联合
人工智能·python·算法
你的论文学长20 分钟前
对抗知网的 N-Gram 算法:基于语义解耦的【文本重构】与【事实性核验】架构设计
人工智能·算法·重构
WW_千谷山4_sch22 分钟前
MYOJ_7788:(洛谷P3387)【模板】缩点(有关强连通分量)
c++·算法·深度优先·动态规划·图论·拓扑学
枫叶丹423 分钟前
【Qt开发】Qt界面优化(六)-> Qt样式表(QSS) 伪类选择器
c语言·开发语言·c++·qt
小O的算法实验室24 分钟前
2026年IEEE TCYB SCI1区TOP,少即是多:一种用于大规模优化的小规模学习粒子群算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进