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

中序遍历的两种实现——二叉树专题复习

在这里插入图片描述
递归实现:

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {// 定义一个结果列表,用于存储遍历的结果List<Integer> res = new ArrayList<>();public List<Integer> inorderTraversal(TreeNode root) {// 调用递归的中序遍历方法inorder(root);// 返回中序遍历的结果列表return res;}// 递归的中序遍历方法public void inorder(TreeNode root){// 如果当前节点为空,则返回if(root == null) return;// 递归地对左子树进行中序遍历inorder(root.left);// 将当前节点的值添加到结果列表res.add(root.val);// 递归地对右子树进行中序遍历inorder(root.right);}
}

递归和迭代的中序遍历在逻辑上是等价的,它们都遵循“左-根-右”的遍历顺序。区别在于递归的时候隐式地维护了一个栈,而我们在迭代的时候需要显式地将这个栈模拟出来,其他都相同,具体实现可以看下面的代码。

迭代实现:

class Solution {// 定义一个列表来存储遍历的结果List<Integer> list = new ArrayList<>();// 定义一个双端队列来模拟栈,用于迭代中序遍历Deque<TreeNode> que = new LinkedList<>();public List<Integer> inorderTraversal(TreeNode root) {// 调用迭代的中序遍历方法inorder(root);// 返回中序遍历的结果列表return list;}// 迭代的中序遍历方法public void inorder(TreeNode root){// 如果当前节点为空,则返回if(root == null) return;// 当当前节点不为空或双端队列不为空时,执行循环while(root != null || !que.isEmpty()){// 当当前节点不为空时,将其推入双端队列// 并移动到当前节点的左子节点while(root != null){que.push(root);root = root.left;}// 当当前节点为空时,说明左子树已遍历完成// 弹出双端队列的顶部元素,即当前节点的右子节点root = que.pop();// 将弹出的节点的值添加到结果列表list.add(root.val);// 移动到当前节点的右子节点root = root.right;}}
}
http://www.lryc.cn/news/391734.html

相关文章:

  • python 基础综合应用——小开发
  • 算法金 | 我最常用的两个数据可视化软件,强烈推荐
  • 【机器学习实战】Baseline精读笔记
  • Redis 缓存问题及解决
  • RISC-V的历史与设计理念
  • 山西车间应用LP-LP-SCADA系统的好处有哪些
  • setjmp和longjmp函数使用
  • vue-org-tree搜索到对应项高亮展开
  • FullCalendar日历组件集成实战(17)
  • 【图像分割】mask2former:通用的图像分割模型详解
  • 【不锈钢酸退作业区退火炉用高温辐射计快速安装】
  • Studying-代码随想录训练营day29| 134. 加油站、135. 分发糖果、860.柠檬水找零、406.根据身高重建队列
  • Understanding Zero Knowledge Proofs (ZKP)
  • 微信小程序 DOM 问题
  • 可视化作品集(03):旅游景区的应用,美爆啦。
  • 嵌入式实时操作系统:Intewell操作系统与VxWorks操作系统有啥区别
  • PCDN技术如何提高内容分发效率?(壹)
  • Java 中Json中既有对象又有数组的参数 如何转化成对象
  • 什么是数据挖掘(python)
  • 【Tomcat】Linux下安装帆软(fineReport)服务器 Tomcat
  • C++ | Leetcode C++题解之第213题打家劫舍II
  • windows系统中快速删除node_modules文件
  • Spring MVC数据绑定和响应——页面跳转(一)返回值为void类型的页面跳转
  • CSS动画keyframes简单样例
  • LabVIEW风机跑合监控系统
  • sql语句练习注意点
  • 如视“VR+AI”实力闪耀2024世界人工智能大会
  • 华为云交付模式和技术支持
  • RK3568平台(opencv篇)ubuntu18.04上安装opencv环境
  • R-CNN:深度学习在目标检测中的革命