二叉树的递归遍历(Javascript)

Posted BAEBAE996

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二叉树的递归遍历(Javascript)相关的知识,希望对你有一定的参考价值。

3种常见的遍历方式如下:
中序遍历:左子节点->根节点->右子节点
先序遍历:根节点->左子节点->右子节点
后序遍历:左子节点->右子节点->根节点

为方便记忆,可以理解为根节点的相对位置
中序:根节点出现在左右子树中间
先序:根节点出现在子树之前
后序:根节点出现在子树之后

树节点的定义

/**
 * 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 inorderTraversal = function(root) {
    if(root===null){
        return []
    }
    var res=new Array()
    const inorder=function(root) {
        if(!root){
            return
        }
        inorder(root.left)
        res.push(root.val)
        inorder(root.right)
    }
    inorder(root)
    return res
};

先序遍历:

var preorderTraversal = function(root) {
    if(root===null){
        return []
    }
    var res=new Array()
    const preorder=function(root) {
        if(!root){
            return
        }
        res.push(root.val)
        preorder(root.left)
        preorder(root.right)
    }
    preorder(root)
    return res
};

后序遍历:

var postorderTraversal = function(root) {
    if(root===null){
        return []
    }
    var res=new Array()
    const postorder=function(root) {
        if(!root){
            return
        }
        postorder(root.left)
        postorder(root.right)
        res.push(root.val)
    }
    postorder(root)
    return res
};






以上是关于二叉树的递归遍历(Javascript)的主要内容,如果未能解决你的问题,请参考以下文章

二叉树的递归遍历(Javascript)

二叉树的非递归遍历怎么写?

二叉树的非递归遍历

二叉树的遍历(递归+迭代)

二叉树的遍历(递归+迭代)

九十五二叉树的递归和非递归的遍历算法模板