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

一、森林定义

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


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

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

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

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


三、核心特点

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

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

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

对比:

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

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


四、遍历对应关系

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

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


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

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

顺着根的右链不断拆分

每一段分别还原成普通树


六、口诀

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

相关推荐
海清河晏1112 小时前
数据结构 | 双循环链表
数据结构·链表
py有趣2 小时前
力扣热门100题之编辑距离
数据结构·算法·leetcode
努力努力再努力wz3 小时前
【Linux网络系列】万字硬核解析网络层核心:IP协议到IP 分片重组、NAT技术及 RIP/OSPF 动态路由全景
java·linux·运维·服务器·数据结构·c++·python
谭欣辰4 小时前
AC自动机:多模式匹配的高效利器
数据结构·c++·算法
历程里程碑5 小时前
MySQL事务深度解析:ACID到MVCC实战+万字长文解析
开发语言·数据结构·数据库·c++·sql·mysql·排序算法
qiqsevenqiqiqiqi5 小时前
MC0550鱼肠剑试锋芒
数据结构·算法
仍然.5 小时前
算法题目---链表
数据结构·算法·链表
周末也要写八哥7 小时前
最长递增子序列典型应用题目详解
数据结构·算法
iiiiyu7 小时前
常用API(StringJoiner类 & Math类 & System类)
java·大数据·开发语言·数据结构·编程语言