二叉树的遍历和线索二叉树--由遍历序列构造二叉树

一、核心结论

1.先序 + 中序 → 唯一确定一棵二叉树 ✔

2.后序 + 中序 → 唯一确定一棵二叉树 ✔

3.先序 + 后序 → 不能唯一确定二叉树 ❌

  1. 单独一种遍历序列:无法还原二叉树

二、三种遍历顺序回顾

  1. 先序:根 左 右

  2. 中序:左 根 右

  3. 后序:左 右 根


一、已知 先序 + 中序 → 构造二叉树

步骤口诀

  1. 先序第一个元素 = 整棵树根

  2. 去中序里找根 → 划分左子树序列、右子树序列

  3. 先序去掉根,按左右长度分割 → 左先序、右先序

  4. 递归重复上面步骤,直到所有节点用完

举例演示

先序:`A B D E C F`

中序:`D B E A F C`

  1. 先序第一个A 是根

  2. 中序拆分:

左子树:`D B E`

根:A

右子树:`F C`

  1. 先序拆分:

左先序:`B D E`

右先序:`C F`

  1. 递归左子树:

先序左:B D E → B是左子树根

中序左:D B E → 左D,右E

  1. 递归右子树:

先序右:C F → C是右子树根

中序右:F C → 左F,无右

最终画出完整二叉树。


二、已知 后序 + 中序 → 构造二叉树

步骤口诀

  1. 后序最后一个元素 = 整棵树根

  2. 中序找根 → 分左、右子树

  3. 后序去掉末尾根,按长度分割左、右后序

  4. 递归构建左右子树

举例

后序:`D E B F C A`

中序:`D B E A F C`

  1. 后序最后 A 是根

  2. 中序分:左 `D B E` ,右 `F C`

  3. 后序拆分:左后序 `D E B`,右后序 `F C`

  4. 递归重复即可


三、为什么 先序+后序 不能唯一确定?

  • 先序:根 左 右

  • 后序:左 右 根

无法区分一个结点是左孩子还是右孩子

比如只有根+一个孩子:

先序AB,后序BA

既可以A左孩子B,也可以A右孩子B

两棵不同树,遍历序列完全一样


四、规律总结

  1. 找根永远靠先

2.分左右子树永远靠中序

  1. 子树长度严格相等:

中序左长度 = 先序左长度 = 后序左长度

  1. 递归思路:根 → 左子树递归 → 右子树递归

五、总结

  1. 由两种遍历序列唯一确定二叉树,必须包含中序序列

  2. n 个结点二叉树,先序、中序、后序序列长度都为 n

  3. 叶子结点在先序、后序中的相对顺序不变

  4. 左右子树交换,先序↔后序改变,中序不变

相关推荐
北域码匠15 小时前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦7 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠8 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾8 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8219 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q9 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒9 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记9 天前
单项不带头不循环链表
数据结构·链表
小糯米6019 天前
JS 数组
数据结构·算法·排序算法
小欣加油9 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展