题解 | #大数加法#

大数加法

https://www.nowcoder.com/practice/11ae12e8c6fe48f883cad618c2e81475

class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 计算两个数之和
     * @param s string字符串 表示第一个整数
     * @param t string字符串 表示第二个整数
     * @return string字符串
     */
    string solve(string s, string t) {
        int len = max(t.length(), s.length());
        reverse(s.begin(), s.end());
        reverse(t.begin(), t.end());
        vector<int> addVC(len + 1, 0);
        string s2 = "";
        for (int i = 0; i < len; i++) {
            int sum = (i < s.length() ? s[i] - '0' : 0) + (i < t.length() ? t[i] - '0' : 0)
                      + addVC[i];
            if (sum >= 10)
                addVC[i + 1] = 1;
            s2 += to_string((sum % 10));
        }
        s2 += addVC[len] == 0 ? "" : "1";
        reverse(s2.begin(), s2.end());
        return s2;
    }
};

全部评论

相关推荐

白火同学:能。我当初应届沟通了1200,收简历50,面试10左右吧,加油投吧
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务