题目描述
两个非空链表表示两个非负整数,各位数字逆序存储,求两数之和也用链表表示。
解题思路
逐位相加,维护进位。注意最高位可能产生新的进位。
while l1 or l2 or carry 优雅地处理了不同长度和最终进位。divmod(s, 10) 同时得到商(进位)和余数(当前位)。
代码实现
python
class Solution:
def addTwoNumbers(self, l1, l2):
dummy = tail = ListNode()
carry = 0
while l1 or l2 or carry:
s = carry
if l1:
s += l1.val
l1 = l1.next
if l2:
s += l2.val
l2 = l2.next
carry, s = divmod(s, 10)
tail.next = ListNode(s)
tail = tail.next
return dummy.next复杂度分析
- 时间复杂度: O(max(m,n)
- 空间复杂度: O(max(m,n)
关键要点
- 逐位相加维护进位,divmod 同时得到商和余数。