二叉树的前、中和后序遍历的递归与迭代实现

1. 前序遍历

1.1 递归

/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @return {number[]}
 */
var preorderTraversal = function(root) {
   
    let result = []
    traversal(root, result)
    return result
};

function traversal(root, res) {
   
    if(root == null) return
    res.push(root.val)
    traversal(root.left, res)  // 左子树
    traversal(root.right, res)  // 右子树
}

1.2 迭代

var preorderTraversal = function (root) {
   
    if (root == null) return []
    let result = []
    let stash = [root]
    while (stash.length) {
   
        const curNode = stash.pop()
        // 第一步的时候 先访问根节点
        result.push(curNode.val)

        // 现加入栈的是右子树然后再是左子树 这样从栈中先弹出的就是左子树 后弹出的才子右子树
        if (curNode.right) stash.push(curNode.right)
        if (curNode.left) stash.push(curNode.left)
    }
    return result
};

2. 中序遍历

2.1 递归

var inorderTraversal = function(root) {
   
    let result = []
    let traversal = (node, res) => {
   
        if(node == null) return
        // 左
        traversal(node.left, res)
        // 中
        res.push(node.val)
        // 右
        traversal(node.right, res)
    }

    traversal(root, result)

    return result
};

2.2 迭代

var inorderTraversal = function (root) {
   
    let result = []

    let stash = []

    let node = root

    while (node || stash.length) {
   
        // 遍历左子树
        while (node) {
   
            stash.push(node)
            node = node.left
        }
        // 中
        node = stash.pop()
        result.push(node.val)
        // 右
        node = node.right
    }

    return result
};

3. 后序遍历

3.1 递归

var postorderTraversal = function(root) {
   
    let result = []

    let traversal = (node, res) => {
   
        if(node == null) return
        // 左
        traversal(node.left, res)
        // 右
        traversal(node.right, res)
        // 中
        res.push(node.val)
    }
    
    traversal(root, result)

    return result
};

3.2 迭代

var postorderTraversal = function (root) {
   
    if(!root) return []

    let result = []
    let stash = [root]

    while (stash.length) {
   
        let curNode = stash.pop()

        result.unshift(curNode.val)   // 核心unshift
        if (curNode.left) stash.push(curNode.left)
        if (curNode.right) stash.push(curNode.right)

    }

    return result
};

最近更新

  1. TCP协议是安全的吗?

    2023-12-06 23:08:07       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-06 23:08:07       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-06 23:08:07       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-06 23:08:07       18 阅读

热门阅读

  1. quickapp_快应用_DOM节点

    2023-12-06 23:08:07       34 阅读
  2. 第2节:Vue3 模板语法

    2023-12-06 23:08:07       32 阅读
  3. ReadWriteLock 和 StampedLock 的比较与解析

    2023-12-06 23:08:07       38 阅读
  4. 使用Redis实现购物车后端处理

    2023-12-06 23:08:07       34 阅读
  5. MSSQL注入的小白常见问题答案解析

    2023-12-06 23:08:07       30 阅读
  6. Redis 实战缓存

    2023-12-06 23:08:07       38 阅读
  7. sql 注入 ctf wiki

    2023-12-06 23:08:07       42 阅读