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

Binary Tree Preorder Traversal

Leetcode Problem 144: Binary Tree Preorder Traversal

Problem Summary

Given the root of a binary tree, return its nodes' values in pre-order traversal order (root → left subtree → right subtree).

Constraints:

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

Techniques

  • Stack
  • Tree
  • Depth-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)
    }
}


// Iterative Preorder Traversal

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

    let stack = [root]
    let preorder: number[] = []

    while (stack.length > 0) {
        const current = stack.pop()!
        preorder.push(current.val)

        if (current.right) {
            stack.push(current.right)
        }

        if (current.left) {
            stack.push(current.left)
        }
    }

    return preorder
}

// Recursive Preorder Traversal
function traverse(node: TreeNode | null, preorder: number[]) {
    if (!node) {
        return
    }

    preorder.push(node.val)

    traverse(node.left, preorder)
    traverse(node.right, preorder)
}

function preorderTraversalRecursive(root: TreeNode | null): number[] {
    const preorder: number[] = []

    traverse(root, preorder)
    return preorder
}