题解 | #大数加法#
大数加法
https://www.nowcoder.com/practice/11ae12e8c6fe48f883cad618c2e81475
class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * 计算两个数之和 * @param s string字符串 表示第一个整数 * @param t string字符串 表示第二个整数 * @return string字符串 */ string solve(string s, string t) { // write code here if (s.size() == 0) return t; if (t.size() == 0) return s; int carry = 0; int i = s.size() - 1, j = t.size() - 1; string tmp; while (i >= 0 || j >= 0) { int a, b, k; a = i < 0 ? 0 : s[i] - '0'; b = j < 0 ? 0 : t[j] - '0'; k = (a + b + carry) % 10; carry = (a + b + carry) / 10; i--; j--; tmp += k + '0'; } if (carry) { tmp += (carry + '0'); } reverse(tmp.begin(), tmp.end()); return tmp; } };