CodeTop415 字符串相加

字符串相加

题目

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

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

示例 1:

1
2
输入:num1 = "11", num2 = "123"
输出:"134"

示例 2:

1
2
输入:num1 = "456", num2 = "77"
输出:"533"

示例 3:

1
2
输入:num1 = "0", num2 = "0"
输出:"0"

提示:

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

题解

利用双指针从后向前处理每一位数字,carry来记录溢位的情况。用n1,n2来记录双指针的数字,如果指针溢出就置为0。

1
2
3
4
5
6
7
8
9
10
11
class Solution:
def addStrings(self, num1: str, num2: str) -> str:
i,j = len(num1)-1,len(num2)-1
result,carry = "",0
while i>=0 or j>=0:
n1 = int(num1[i]) if i>=0 else 0
n2 = int(num2[j]) if j>=0 else 0
result = str((carry+n1+n2)%10) + result #求余数
carry = (carry+n1+n2)//10
i, j = i-1,j-1
return result if carry==0 else "1"+result