Standard reverse a linked list question. Implemented both iteratively and recursively.
class Solution:
def reverseList(self, head: Optional[ListNode]) -> Optional[ListNode]:
node = head
prev = None
while node != None:
next_node = node.next
node.next = prev
prev = node
node = next_node
return prev
class Solution:
def reverseList(self, head: Optional[ListNode]) -> Optional[ListNode]:
def helper(head, prev):
if not head:
return prev
temp = head.next
head.next = prev
return helper(temp, head)
return helper(head, None)