树、森林——树、森林与二叉树的转换(森林转换为二叉树)

一、森林定义

多棵互不相交的树,合在一起就是森林


二、森林转二叉树 三大步骤

每一棵树,单独转成二叉树规则:左孩子,右兄弟

第一棵树根不动第二棵树的根 → 作为第一棵树根的右孩子第三棵树的根 → 作为第二棵树根的右孩子依次向右串联

整理结构,就是森林对应的唯一二叉树


三、核心特点

森林转二叉树,根结点一定有右子树

二叉树根左子树:第一棵树

二叉树根右子树:剩下所有森林

对比:

一棵树 → 二叉树:根无右子树

一片森林 → 二叉树:根有右子树


四、遍历对应关系

森林先序遍历 = 对应二叉树 先序遍历

森林中序遍历 = 对应二叉树 中序遍历


五、逆向:二叉树转回森林

若树根有右孩子,说明原先是森林

顺着根的右链不断拆分

每一段分别还原成普通树


六、口诀

一树转二叉右为空多树相连右相通左挂孩子右挂兄根连根来排成龙

相关推荐
如竟没有火炬3 小时前
接雨水22
数据结构·python·算法·leetcode·散列表
ʚ希希ɞ ྀ3 小时前
二叉树的锯齿层序遍历
数据结构·算法
tyung4 小时前
用 Go 实现一个生产级 Ring Buffer Queue:环形数组、位运算取模、批量操作全拆解
数据结构·go
SHARK_pssm6 小时前
【数据结构——复杂度】
c语言·数据结构·经验分享·笔记
故事和你916 小时前
洛谷-【图论2-1】树2
开发语言·数据结构·c++·算法·动态规划·图论
努力努力再努力wz7 小时前
【Qt入门系列】深入理解信号与槽:从事件响应到自定义信号机制
c语言·开发语言·数据结构·数据库·c++·qt·mysql
Ricky_Theseus7 小时前
B树和B+树的区别
数据结构·b树
爱炼丹的James8 小时前
第二章 数据结构
数据结构
我爱cope8 小时前
【前缀和:3. 无重复字符的最长子串】
数据结构·算法·leetcode
不知名的忻8 小时前
关键路径(Java)
java·数据结构·算法·关键路径