给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和并同样以字符串形式返回。

    你不能使用任何內建的用于处理大整数的库(比如 BigInteger), 也不能直接将输入的字符串转换为整数形式。

    示例 1:

    输入:num1 = “11”, num2 = “123”
    输出:”134”
    示例 2:

    输入:num1 = “456”, num2 = “77”
    输出:”533”
    示例 3:

    输入:num1 = “0”, num2 = “0”
    输出:”0”

    提示:

    1 <= num1.length, num2.length <= 104
    num1 和num2 都只包含数字 0-9
    num1 和num2 都不包含任何前导零


    双指针

    1. class Solution {
    2. public String addStrings(String num1, String num2) {
    3. StringBuffer res = new StringBuffer();
    4. int carry = 0;
    5. int i = num1.length()-1, j = num2.length()-1;
    6. while(i >= 0 || j >= 0){
    7. int sum = carry;
    8. sum += i >= 0 ? num1.charAt(i--)-'0' : 0;
    9. sum += j >= 0 ? num2.charAt(j--)-'0' : 0;
    10. res.append(sum % 10);
    11. carry = sum / 10;
    12. }
    13. if(carry > 0) res.append(1);
    14. return res.reverse().toString();
    15. }
    16. }

    高精度加法

    1. class Solution {
    2. List<Integer>a;
    3. List<Integer>b;
    4. public String addStrings(String num1, String num2) {
    5. a = new ArrayList<>();
    6. b = new ArrayList<>();
    7. for(int i = num1.length()-1; i >= 0; --i)a.add(num1.charAt(i)-'0');
    8. for(int i = num2.length()-1; i >= 0; --i)b.add(num2.charAt(i)-'0');
    9. List<Integer> res = add(a,b);
    10. String s = "";
    11. for(int i = res.size()-1; i >= 0; --i) s += res.get(i);
    12. return s;
    13. }
    14. public List<Integer> add(List<Integer> a, List<Integer> b){
    15. List<Integer> res = new ArrayList<>();
    16. int carry = 0;
    17. for(int i = 0; i < a.size() || i < b.size(); ++i){
    18. int sum = carry;
    19. sum += i < a.size() ? a.get(i) : 0;
    20. sum += i < b.size() ? b.get(i) : 0;
    21. res.add(sum % 10);
    22. carry = sum / 10;
    23. }
    24. if(carry > 0) res.add(1);
    25. return res;
    26. }
    27. }