树 —— 深度优先遍历

数据结构:栈
使用递归:判断传入的节点是否为空,为空就return,根据遍历顺序丢给调用函数,再把当前的值赋给res数组

// 前序遍历
// var preOrder = function (root){
//     let res = []
//     let stack = []
//     root && stack.push(root)
//     while (stack.length>0){
//         let temp = stack.pop()
//         res.push(temp.val)
//         temp.right && stack.push(temp.right)
//         temp.left && stack.push(temp.left)
//     }
//     return res
// }

var preOrder = function (root){
    let res = []
    function traversal(root){
        if (!root){
            return
        }
        res.push(root.val)
        traversal(root.left)
        traversal(root.right)
    }
    traversal(root)
    return res
}

// 中序遍历
var inOrder = function (root){
    let res = []
    function traversal(root){
        if (!root){
            return
        }
        traversal(root.left)
        res.push(root.val)
        traversal(root.right)
    }
    traversal(root)
    return res
}


// 后序遍历
var thenOrder = function (root){
    let res = []
    function travelsal(root){
        if (!root){
            return
        }
        travelsal(root.left)
        travelsal(root.right)
        res.push(root.val)
    }
    travelsal(root)
    return res
}

上一篇:line-hight


下一篇:HDU 1028 Ignatius and the Princess III(生成函数)