字符串相加
题目
给定两个字符串形式的非负整数 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
|