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

回忆一下递归实现

javascript 复制代码
/**
/**
 * 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) {
	var retArr = []
	if (!root) return retArr
	var hlpFunc = (r) => {
		if(!r) return 
		if (r.left) { helpFunc(r.left) }
		retArr.push(r.val)
		if (r.right) { hlepFunc(r.right) }
	}
	helpFunc(root)
	return retArr
}

用模拟栈来实现(方法一)( 一二写法不一样,但是本质是一致)

javascript 复制代码
var inorderTraversal = function(root) {
	var retArr = []
	if (!root) return retArr
	let cur = root
	let stack = []
	while(stack.length !==0 || cur) {
		if (cur) {
			stack.push(cur)
			cur = cur.left
		} else {
			var tmp = stack.pop()
			retArr.push(temp.val)
			cur = temp.right
		}
	}

	return retArr

}

用模拟栈来实现(方法二)( 一二写法不一样,但是本质是一致)

javascript 复制代码
var inorderTraversal = function(root) {
	var retArr = []
	if (!root) return retArr
	let cur = root
	let stack = []
	while(stack.length !==0 || cur) {
		while(cur) {
			stack.push(cur)
			cur = cur.left
		}
		var tmp = stack.pop()
		retArr.push(tmp.val)
		cur = tmp.right
	}

	return retArr

用模拟栈来实现(方法三)( 与方法一是逆向操作)

javascript 复制代码
var inorderTraversal = function(root) { 
    var retArr = []
    if (!root) return retArr
    let stack = []
    let cur =root
    while( stack.length !== 0 || cur ) {
        if (cur) {
            stack.push(cur)
            cur = cur.right
        } else {
            var tmp = stack.pop()
            retArr.push(tmp.val)
            cur = tmp.left
        }
    }
    return retArr.reverse()
}

根左右 【前序】

左根右 【中序】

根右左 【后序--逆向】

右根右 【中序--逆向】

相关推荐
dy17171 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
焦耳加热3 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn4 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6064 小时前
常用排序算法核心知识点梳理
算法·排序
2501_915918415 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂5 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技5 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育
gnip5 小时前
JavaScript二叉树相关概念
前端
蒋星熠6 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
attitude.x6 小时前
PyTorch 动态图的灵活性与实用技巧
前端·人工智能·深度学习