您好,欢迎来到步遥情感网。
搜索
您的当前位置:首页【数据结构与算法】后续遍历的非递归实现

【数据结构与算法】后续遍历的非递归实现

来源:步遥情感网

回忆一下递归实现


/**
/**
 * 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 postorderTraversal = function(root) {
	var retArr = []
	if (!root) return retArr
	var helpFunc = (r)=>{
		if (!r) return 
		helpFunc(r.left)
		helpFunc(r.right)
		retArr.push(r.val)
	}
	helpFunc(root)
	return retArr
}

用模拟栈来实现(方法一) 逆向


var postorderTraversal = function(root) {
    if(!root) return []
    let cur = root
    var stack = []
    var retArr = []
    while(stack.length !== 0 || cur){
        // 右节点入栈
        if (cur) {
            stack.push(cur)
            retArr.push(cur.val)
            cur = cur.right
        }   else {
            var tmp = stack.pop()
            cur = tmp.left
        }

    }
    return retArr.reverse()
 }

用模拟栈来实现(方法二 ) (单栈)


var postorderTraversal = function(root) {
    if(!root) return []
    let cur = root
    var stack = []
    var retArr = []
    var r = null // 记录访问过的子节点
    while(stack.length !== 0 || cur){
        // 左节点入栈
        if (cur) {
            stack.push(cur)
            cur = cur.left
        }   else {

            cur = stack[stack.length - 1] // 读取栈顶元素,非弹出
            // 如果右子树存在,并且没有被访问
            if (cur.right && cur.right !=r) {
                cur = cur.right
            } else {
                // 弹出并访问
                var tm = stack.pop()
                retArr.push(tm.val)
                r = cur
                cur = null
            }
        }

    }
    return retArr
 }

根左右 【前序】
左根右 【中序】

根右左 【后序–逆向】
右根左 【中序–逆向】

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- obuygou.com 版权所有 赣ICP备2024042798号-5

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务