Skip to content

Latest commit

 

History

History
47 lines (36 loc) · 1.05 KB

116.Populating-Next-Right-Pointers-in-Each-Node.md

File metadata and controls

47 lines (36 loc) · 1.05 KB

116. Populating Next Right Pointers in Each Node

Difficulty: Medium

URL

https://leetcode.com/problems/populating-next-right-pointers-in-each-node/

Solution

Approach 1: Level Order Traversal with a Queue

$O(n)$

The code is shown below:

"""
# Definition for a Node.
class Node:
    def __init__(self, val: int = 0, left: 'Node' = None, right: 'Node' = None, next: 'Node' = None):
        self.val = val
        self.left = left
        self.right = right
        self.next = next
"""
from collections import deque

class Solution:
    def connect(self, root: 'Optional[Node]') -> 'Optional[Node]':
        if not root:
            return root
        
        q = deque([root])
        while q:
            size = len(q)
            prev = None
            for _ in range(size):
                node = q.popleft()
                if prev:
                    prev.next = node
                if node.left:   q.append(node.left)
                if node.right:  q.append(node.right)
                prev = node
        
        return root