-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path2_add_two_numbers
More file actions
62 lines (50 loc) · 1.54 KB
/
2_add_two_numbers
File metadata and controls
62 lines (50 loc) · 1.54 KB
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# 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
"""
curr1, curr2, num1, num2, count1, count2 = l1, l2, 0, 0, 0, 0
while curr1:
num1 += curr1.val * (10 ** count1)
count1 += 1
curr1 = curr1.next
while curr2:
num2 += curr2.val * (10 ** count2)
count2 += 1
curr2 = curr2.next
summ = num1 + num2
dummy = ListNode(0)
head = dummy
if summ == 0 : return ListNode(0)
while summ != 0:
head.next = ListNode(summ%10)
summ = summ//10
head = head.next
return dummy.next
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def addTwoNumbers(self, l1, l2):
dummy = cur = ListNode(0)
carry = 0
while l1 or l2 or carry:
if l1:
carry += l1.val
l1 = l1.next
if l2:
carry += l2.val
l2 = l2.next
cur.next = ListNode(carry%10)
cur = cur.next
carry //= 10
return dummy.next