forked from csujedihy/lc-all-solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreverse-linked-list.py
60 lines (51 loc) · 1.5 KB
/
reverse-linked-list.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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
# Definition for singly-linked list.
# class ListNode(object):
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution(object):
def reverseList(self, root):
if not root or not root.next:
return root
ret = self.reverseList(root.next)
root.next.next = root
root.next = None
return ret
def _reverseList(self, head):
pre = None
cur = head
while cur:
tmp = cur.next
cur.next = pre
pre = cur
cur = tmp
return pre
# iteratively as queue head inserting
def __reverseList(self, head):
"""
:type head: ListNode
:rtype: ListNode
"""
dHead = dummy = ListNode(-1)
p = head
while p:
tmp = dummy.next
dummy.next = p
p = p.next
dummy.next.next = tmp
return dHead.next
# easily leads to a circle. Remove current node's next after recursive call.
def ___reverseList(self, head):
self.newHead = None
def rec(head):
if not head:
return head
p = rec(head.next)
head.next = None
if p:
p.next = head
else:
self.newHead = head
return head
rec(head)
return self.newHead