二叉树的遍历和线索二叉树--线索二叉树

一、引出线索二叉树的原因

  1. 普通二叉链表:n 个结点,总共有 `2n` 个指针域

  2. 有效孩子指针只用了 `n-1` 个

  3. 剩余n+1 个指针是空指针,极度浪费空间

思路:把空指针利用起来

  • 左空指针 → 指向该结点---遍历前驱

  • 右空指针 → 指向该结点---遍历后继

这种用指针记录遍历先后关系的二叉树 = 线索二叉树


二、线索二叉树结点结构

比普通二叉结点多两个标记位:

  • `data`:数据

  • `lchild`:左孩子 / 前驱线索

  • `rchild`:右孩子 / 后继线索

  • `ltag`:左标记

  • `ltag = 0`:lchild 指向左孩子

  • `ltag = 1`:lchild 是前驱线索

  • `rtag`:右标记

  • `rtag = 0`:rchild 指向右孩子

  • `rtag = 1`:rchild 是后继线索


三、三种线索二叉树

按照遍历方式划分:

1.先序线索二叉树

  1. 中序线索二叉树

  2. 后序线索二叉树


四、核心特点

  1. 充分利用空闲空指针,不额外占用内存

2.不用递归、不用栈,就可以遍历整棵树

  1. 可以快速查找结点在遍历序列中的前驱、后继

  2. 遍历速度更快,空间复杂度更低

  3. 本质:二叉树 + 静态链表


五、中序线索二叉树规律

  1. 最左结点:左线索为空,无前驱

  2. 最右结点:右线索为空,无后继

  3. 叶子结点:左右全是线索

  4. 二叉树 + 头尾结点连成循环双向线索链表

找前驱后继

  • 叶子结点:直接顺着线索找

  • 非叶子结点:依然要靠左右子树查找


六、优缺点

优点

  1. 非递归遍历二叉树,无需栈

  2. 快速查询前驱、后继结点

  3. 空间利用率高

缺点

  1. 插入、删除结点麻烦,需要重新修改线索

  2. 先序、后序线索树查找前驱后继复杂

  3. 不如递归遍历代码直观

相关推荐
散峰而望7 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
躺不平的理查德7 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
刃神太酷啦7 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
多加点辣也没关系8 小时前
数据结构与算法|第六章:队列
数据结构·算法·队列
我是无敌小恐龙9 小时前
Java基础入门Day10 | Object类、包装类、大数/日期类、冒泡排序与Arrays工具类 超详细总结
java·开发语言·数据结构·算法·贪心算法·排序算法·动态规划
流年如夢10 小时前
单链表的应用 --> 简单通讯录的实现
android·数据结构·链表
流年如夢12 小时前
单链表Ⅲ(LeetCode)
数据结构·算法·leetcode·职场和发展
洛水水13 小时前
【数据结构】红黑树详解
数据结构·红黑树
炸膛坦客13 小时前
嵌入式 - 数据结构与算法:(1-9)数据结构 - 队列(Queue)
c语言·数据结构
AbandonForce14 小时前
哈希表(HashTable,散列表)个人理解
开发语言·数据结构·c++·散列表