給定兩個字符串形式的非負整數?num1 和num2?,計算它們的和。
注意:
num1 和num2?的長度都小于 5100.
num1 和num2 都只包含數字?0-9.
num1 和num2 都不包含任何前導零。
你不能使用任何內建 BigInteger 庫,?也不能直接將輸入的字符串轉換為整數形式。
思路:模擬小學加法豎式計算即可,注意長度不同如何處理。
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 n1 = i >= 0 ? num1.charAt(i) - '0' : 0;int n2 = j >= 0 ? num2.charAt(j) - '0' : 0;int tmp = n1 + n2 + carry;carry = tmp / 10;res.append(tmp % 10);i--; j--;}if(carry == 1) res.append(1);return res.reverse().toString();}
}
?