Runtime: 208 ms, faster than 16.64% of Python3 online submissions for Add Two Numbers.
原谅我,指针我已经不知道知道哪里去了。。。。
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def addTwoNumbers(self, l1, l2):
"""
:type l1: ListNode
:type l2: ListNode
:rtype: ListNode
"""
head = ListNode(0)
l3 = head
tmp = 0
while(l1 and l2):
s = l1.val + l2.val + tmp
if s < 10:
l3.next = ListNode(s)
tmp = 0
else:
l3.next = ListNode(s - 10)
tmp = 1
l1 = l1.next
l2 = l2.next
l3 = l3.next
l4 = l2 or l1
while(tmp == 1 and l4):
s = l4.val + tmp
if s >= 10:
tmp = 1
l3.next = ListNode(s - 10)
l4 = l4.next
l3 = l3.next
else:
tmp = 0
l3.next = ListNode(s)
l4 = l4.next
l3 = l3.next
if tmp == 0 and l4:
l3.next = l4
if tmp == 1 and l4 == None:
l3.next = ListNode(1)
return head.next