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

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

  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. 不如递归遍历代码直观

相关推荐
刘马想放假3 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠4 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦11 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠12 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾12 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82112 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q12 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒12 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记12 天前
单项不带头不循环链表
数据结构·链表
小糯米60112 天前
JS 数组
数据结构·算法·排序算法