码迷,mamicode.com
首页 > 编程语言 > 详细

二叉树的递归遍历(Javascript)

时间:2020-11-01 09:45:25      阅读:19      评论:0      收藏:0      [点我收藏+]

标签:traversal   UNC   遍历   code   nod   方便   ini   tor   javascrip   

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)

标签:traversal   UNC   遍历   code   nod   方便   ini   tor   javascrip   

原文地址:https://www.cnblogs.com/baebae996/p/13905343.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!