【数据结构与算法】先序遍历(前序遍历)的非递归实现

回忆一下递归实现

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 helpFunc = (r) => {
        if (!r)return 
		retArr.push(r.val)
		if (r.left) { helpFunc(r.left) }
		if (r.right) { helpFunc(r.right)}
	}
	helpFunc(root)
	return retArr
}

用模拟栈来实现

javascript 复制代码
var preorderTraversal = function(root) {
	var retArr = []
	if (!root) return retArr
	var stack = []
	stack.push(root)
	while(stack.length !== 0) {
		var popE = stack.pop()
		retArr.push(popE.val)
		if (popE.right) {
			stack.push(popE.right)
		}
		if (popE.left) {
			stack.push(popE.left)
		}
	}
	return retArr
}
相关推荐
摸鱼的春哥2 小时前
Agent教程15:认识LangChain(中),状态机思维
前端·javascript·后端
明月_清风2 小时前
告别遮挡:用 scroll-padding 实现优雅的锚点跳转
前端·javascript
明月_清风2 小时前
原生 JS 侧边栏缩放:从 DOM 监听到底层优化
前端·javascript
董董灿是个攻城狮12 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
炫饭第一名16 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
进击的尘埃17 小时前
Vue3 响应式原理:从 Proxy 到依赖收集,手撸一个迷你 reactivity
javascript
willow17 小时前
JavaScript数据类型整理1
javascript
LeeYaMaster17 小时前
20个例子掌握RxJS——第十一章实现 WebSocket 消息节流
javascript·angular.js
UIUV18 小时前
RAG技术学习笔记(含实操解析)
javascript·langchain·llm
AI软著研究员19 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法