【高阶数据结构】二叉树的非递归遍历
创始人
2024-05-02 14:56:24

🌈欢迎来到数据结构专栏~~二叉树的非递归遍历


  • (꒪ꇴ꒪(꒪ꇴ꒪ )🐣,我是Scort
  • 目前状态:大三非科班啃C++中
  • 🌍博客主页:张小姐的猫~江湖背景
  • 快上车🚘,握好方向盘跟我有一起打天下嘞!
  • 送给自己的一句鸡汤🤔:
  • 🔥真正的大师永远怀着一颗学徒的心
  • 作者水平很有限,如果发现错误,可在评论区指正,感谢🙏
  • 🎉🎉欢迎持续关注!
    在这里插入图片描述

请添加图片描述

二叉树的非递归遍历

  • 🌈欢迎来到数据结构专栏~~二叉树的非递归遍历
      • 1️⃣二叉树的前序遍历
      • 2️⃣二叉树的中序遍历
      • 3️⃣二叉树的后序遍历
  • 📢写在最后

请添加图片描述

1️⃣二叉树的前序遍历

题目链接:传送

在这里插入图片描述

本文我们都采用非递归的方法去讲解:

本质上是在模拟递归,因为在递归的过程中使用了系统,所以在迭代的解法中常用Stack来模拟系统栈

思路:

  1. 二叉树的左子树不断入栈,同时也入数组
  2. 当左子树都访问完了,要访问右子树的时候,取出栈顶的top元素,并且子问题访问右子树cur = top->right
  3. 如此一来可以访问完全部的左右子树

在这里插入图片描述

class Solution {
public:vector preorderTraversal(TreeNode* root) {stack st;vector v;TreeNode* cur = root;while(cur || !st.empty()){//开始访问一颗树的左边节点while(cur){v.push_back(cur->val);st.push(cur);cur = cur->left;}//左边节点的右路指针需要访问TreeNode* top = st.top();st.pop();cur = top->right;//子问题访问右树  重点!!}return v;}
};

2️⃣二叉树的中序遍历

题目链接:传送

在这里插入图片描述

思路:

  • 要记住中序:左子树 —— 根 —— 右子树
  • cur 不为空或者栈不为空的时候,就说明还没有遍历完
  • 左边节点全部入栈后,遇到空的时候,就要去栈顶top,并且cur = top->right,变到右子树继续

在这里插入图片描述

class Solution {
public:vector inorderTraversal(TreeNode* root) {stack st;vector v;TreeNode* cur = root;while(cur || !st.empty()){//1、左边节点入栈while(cur){st.push(cur);cur = cur->left;}//2、当左路节点从栈中出来时,应该访问root和右子树了TreeNode* top = st.top();st.pop();v.push_back(top->val);cur = top->right;}return v;}
};

3️⃣二叉树的后序遍历

题目链接:传送

在这里插入图片描述

请添加图片描述
思路:

  1. 和前序中序不一样,访问方式:左子树 —— 右子树 —— 根
  2. 定义一个prev,来识别已经已经访问过的节点
  3. 如果遍历完左边节点,右边节点为空or右边节点已经访问过了,则可以访问root

在这里插入图片描述

class Solution {
public:vector inorderTraversal(TreeNode* root) {stack st;vector v;TreeNode* cur = root;TreeNode* prev = nullptr;while(cur || !st.empty()){//1、左节点入栈while(cur){st.push(cur);cur = cur->left;}//2、当左节点从栈中出来,则表示左子树已经访问过了TreeNode* top = st.top();if(top->right == nullptr || top->right == prev){v.push_back(top->val);prev = top;st.pop();}else{cur = top->right;//子问题访问右子树}}return v;}
};

📢写在最后

acwing永远滴神

在这里插入图片描述

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
篮球运球基本功 篮球运球动作要... 篮球是初中男生们最为喜爱的体育项目之一,甚至部分学生的篮球水平很高,但是平时打球多,并不意味着就一定...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
回归分析结果怎么看 spss回... 性研究领域,无论是现况调查、病例对照研究、还是队列研究,经常遇到分类的健康结局,包括二分类(如:生存...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...