> Uploading knowledge... _
[░░░░░░░░░░░░░░░░░░░░░░░░] 0%
blog logo
> CHICIO CODING_Pixels. Code. Unplugged.

Binary Tree Zigzag Level Order Traversal

Leetcode Problem 103: Binary Tree Zigzag Level Order Traversal

Problem Summary

Given the root of a binary tree, return its node values in zigzag level order — alternating between left-to-right and right-to-left on each successive level. Return the result as a list of lists, one per level.

Constraints:

  • The tree has between 0 and 2,000 nodes.
  • Node values are integers in the range [-100, 100].

Techniques

  • Tree
  • Breadth-First Search
  • Binary Tree

Solution

export class TreeNode {
    val: number
    left: TreeNode | null
    right: TreeNode | null

    constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {
        this.val = (val === undefined ? 0 : val)
        this.left = (left === undefined ? null : left)
        this.right = (right === undefined ? null : right)
    }
}

function zigzagLevelOrder(root: TreeNode | null): number[][] {
    if (!root) {
        return []
    }

    let queue = [root]
    let levels: number[][] = []
    let levelIndex = 0

    while (queue.length > 0) {
        let levelSize = queue.length
        let level = []

        while (levelSize > 0) {
            let currentNode: TreeNode = queue.shift()!

            if (levelIndex % 2 === 0) {
                level.push(currentNode.val)
            } else {
                level.unshift(currentNode.val)
            }

            if (currentNode.left) {
                queue.push(currentNode.left)
            }

            if (currentNode.right) {
                queue.push(currentNode.right)
            }

            levelSize--
        }

        levelIndex++
        levels.push(level)
    }

    return levels
}