当前位置: 首页 > news >正文

算法通关村第七关——递归和迭代实现二叉树前中后序遍历

1.递归

1.1 熟悉递归

所有的递归有两个基本特征:

  1. 执行时范围不断缩小,这样才能触底反弹。
  2. 终止判断在调用递归的前面。

写递归的步骤:

  1. 从小到大递推。
  2. 分情况讨论,明确结束条件。
  3. 组合出完整方法。
  4. 想验证就从大到小画图推演。

1.2 递归实现二叉树的前中后序遍历

/*** @param {TreeNode} root* @return {number[]}*/
var preorderTraversal = function(root) {const nodeArray = [];addNode(root, nodeArray);return nodeArray;   
};function addNode(node, res) {if (!node) {return res;}// 前、中、后序遍历只需调换下面三行代码位置res.push(node.val);	// 中addNode(node.left, res); // 左addNode(node.right, res); // 右
}

2.迭代

2.1 迭代实现二叉树前中后序遍历

迭代主要是模拟一个系统栈出来,将节点压入栈中,再取出。前中序遍历容易理解,后序遍历较为复杂,涉及到反转操作。

前序遍历

 */
/*** @param {TreeNode} root* @return {number[]}*/
var preorderTraversal = function(root) {const nodeQueue = [];if (!root) {return nodeQueue;}const nodeStack = [];let treeNode = root;while (nodeStack.length !== 0 || treeNode) {while (treeNode) {nodeQueue.push(treeNode.val);nodeStack.push(treeNode);treeNode = treeNode.left;}treeNode = nodeStack.pop();treeNode = treeNode.right;}return nodeQueue;  
};

中序遍历

/*** @param {TreeNode} root* @return {number[]}*/
var inorderTraversal = function(root) {const nodeQueue = [];const nodeStack = [];if (!root) {return nodeQueue;}let treeNode = root;while (nodeStack.length !== 0 || treeNode) {		while (treeNode) {nodeStack.push(treeNode);treeNode = treeNode.left;}treeNode = nodeStack.pop()nodeQueue.push(treeNode.val);treeNode = treeNode.right;}return nodeQueue;
};

后序遍历

在这里插入图片描述

分析:

观察后序遍历的结果是:1, 2, 3, 8, 9, 7, 6,如果将其反转的话就是6, 7, 9, 8, 3, 2, 1

反转后的后序遍历与前序遍历相比就是左右反了。前序遍历是中左右,后序遍历是左右中,只要调整前序遍历的左右顺序就可以得到后序遍历。

function postOrderTraversal(root) {const nodeQueue = [];const nodeStack = [];if (!root) {return nodeQueue;}let treeNode = root;while (nodeStack.length !== 0 || treeNode) {while (treeNode) {nodeQueue.push(treeNode.val)nodeStack.push(treeNode);treeNode = treeNode.right;}treeNode = nodeStack.pop();treeNode = treeNode.left();}nodeQueue.reverse();   // 将其进行反转return nodeQueue;
}
http://www.lryc.cn/news/124182.html

相关文章:

  • Datawhale Django后端开发入门Task01 Vscode配置环境
  • django部署到centos服务器上
  • IOS开发-XCode14介绍与入门
  • Interactive Marker Publish Pose All the Time (Interactive Marker通过topic一直发送其状态)
  • 前后端分离------后端创建笔记(04)前后端对接
  • 一站式自动化测试平台-Autotestplat
  • Ansible Service模块,使用 Ansible Service模块进行服务管理
  • 共识算法初探
  • Oracle查询表字段名并拼接
  • 8 张图 | 剖析 Eureka 的首次同步注册表
  • github ssh配置
  • c51单片机串口通信(中断方式接收数据)(单片机--单片机通信)示例代码 附proteus图
  • 腾讯面试题算法还原【游戏安全】
  • vue + less 实现动态主题换肤功能
  • matlab使用教程(15)—图论基础
  • 【量化课程】02_4.数理统计的基本概念
  • 【计算机视觉|生成对抗】改进的生成对抗网络(GANs)训练技术
  • SQLyog中导入CSV文件入库到MySQL中
  • Spring Security6 最新版配置该怎么写,该如何实现动态权限管理
  • CommandLineRunner 和 ApplicationRunner 用于Spring Boot 应用启动后执行特定逻辑
  • 一、Dubbo 简介与架构
  • 软考:中级软件设计师:文件管理,索引文件结构,树型文件结构,位示图,数据传输方式,微内核
  • 实践-CNN卷积层
  • 【设计模式】MVC 模式
  • 看康师傅金桔柠檬X国漫IP跨界出圈,打开IP合作新思路
  • ElementUI的MessageBox的按钮置灰且不可点击
  • pc端与flutter通信失效, Method not found
  • linux 防火墙经常使用的命令
  • Docker desktop安装mysql
  • Java SpringBoot Vue ERP系统