数据结构和算法学习记录——二叉树的非递归遍历(中序遍历、先序遍历、后序遍历)

简介: 数据结构和算法学习记录——二叉树的非递归遍历(中序遍历、先序遍历、后序遍历)

二叉树的非递归遍历运用到堆栈

中序遍历

循环的思路是

  1. 遇到一个节点,就把它压栈,并去遍历它的左子树。
  2. 当左子树遍历结束之后,从栈顶弹出这个节点并访问它。
  3. 然后按其右指针再去按中序的遍历循环去遍历该节点的右子树。

代码实现

void InOrderTraversal(BinTree BT)
{
  BinTree T = BT;
  Stack S = CreatStack();  //创建并初始化堆栈S
  while (T || !IsEmpty(S))        //节点和栈都为空时才停止循环
  {
    while (T)                   //一直向左并将沿途节点压入堆栈
    {
      Push(S, T);       
      T = T->Left;
    }
    if (!IsEmpty(S))            //当遇到左子树为空时,进行出栈
    {
      T = Pop(S);             //弹出栈顶元素
      printf("%5d", T->data); //访问栈顶元素
      T = T->Right;           //转向右子树
    }
  }
}

思路图解

从中序非递归遍历的代码上,可以将压栈时看做是第一次经过节点,将出栈是看做是第二次经过节点。所以结合之前学的递归遍历, 中序的非递归遍历代码中,才会在出栈时(即第二次经过节点时)访问节点。

所以要写出先序的非递归遍历就比较简单了:

先序遍历

将访问放在第一次经过节点时,就变成了先序的非递归遍历代码了。

代码实现

void PreOrderTrversal(BinTree BT)
{
  BinTree T = BT;
  Stack S = CreatStack();  //创建并初始化堆栈S
  while (T || !IsEmpty(S))        //节点和栈都为空时才停止循环
  {
    while (T)                   //一直向左并将沿途节点压入堆栈
    {
      Push(S, T);
      printf("%5d", T->data); //访问栈顶元素
      T = T->Left;
    }
    if (!IsEmpty(S))            //当遇到左子树为空时,进行出栈
    {
      T = Pop(S);             //弹出栈顶元素
      T = T->Right;           //转向右子树
    }
  }
}

再看后序的非递归遍历,似乎上面的代码中只有第一次经过和第二次经过,没有第三次经过节点的了,所以不能在原来的基础上调整代码来实现后序非递归遍历了。

后序遍历

要实现后序非递归遍历,可以借助两个堆栈,一个用于存储遍历的序列,另一个用于存储中间节点。

具体实现的思路:

  1. 初始化两个堆栈s1和s2,将根节点压入s1中。
  2. 从s1中弹出栈顶节点,将其压入s2中。
  3. 如果该节点有左子节点,则将左子节点压入s1中。
  4. 如果该节点有右子节点,则将右子节点压入s1中。
  5. 重复步骤2到步骤4,直到s1为空。
  6. 从s2中依次弹出节点并输出,即可得到后序遍历序列。

思路图解


end



目录
相关文章
|
8天前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
16 1
|
19天前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
数据结构与算法系列学习之串的定义和基本操作、串的储存结构、基本操作的实现、朴素模式匹配算法、KMP算法等代码举例及图解说明;【含常见的报错问题及其对应的解决方法】你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
|
16天前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
65 8
|
19天前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习(8)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
19天前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
20天前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
19天前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
20天前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之顺序表习题精讲【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找习题精讲等具体详解步骤以及举例说明
|
19天前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之王道第2.3章节之线性表精题汇总二(5)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
IKU达人之数据结构与算法系列学习×单双链表精题详解、数据结构、C++、排序算法、java 、动态规划 你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
17天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
91 9