206. Reverse Linked List
Easy
Problem:
Input: head = [1,2,3,4,5]
Output: [5,4,3,2,1]Solution:
Revursive 🔥
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def reverseList(self, head: Optional[ListNode]) -> Optional[ListNode]:
def reverse(node: ListNode, prev: ListNode = None):
if not node:
return prev
next, node.next = node.next, prev
return reverse(next, node)
return reverse(head)Iterative
Last updated