generated from zeikar/issueage
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathadd-two-numbers.py
36 lines (30 loc) · 876 Bytes
/
add-two-numbers.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def addTwoNumbers(self, l1: Optional[ListNode], l2: Optional[ListNode]) -> Optional[ListNode]:
p1 = l1
p2 = l2
head = ListNode()
pr, r = None, head
carry = 0
while p1 != None or p2 != None:
v1, v2 = 0, 0
if p1 != None:
v1 = p1.val
p1 = p1.next
if p2 != None:
v2 = p2.val
p2 = p2.next
r.val = (v1 + v2 + carry) % 10
carry = (v1 + v2 + carry) // 10
pr = r
r.next = ListNode()
r = r.next
if carry != 0:
r.val = 1
else:
pr.next = None
return head