树、森林与二叉树相互转化原理图
来源:互联网 发布:java try单独使用 编辑:程序博客网 时间:2024/06/18 16:37
1、树转换为二叉树
由于二叉树是有序的,为了避免混淆,对于无序树,我们约定树中的每个结点的孩子结点按从左到右的顺序进行编号。
将树转换成二叉树的步骤是:
(1)加线。就是在所有兄弟结点之间加一条连线;
(2)抹线。就是对树中的每个结点,只保留他与第一个孩子结点之间的连线,删除它与其它孩子结点之间的连线;
(3)旋转。就是以树的根结点为轴心,将整棵树顺时针旋转一定角度,使之结构层次分明。
树转换为二叉树的过程示意图
2、森林转换为二叉树
森林是由若干棵树组成,可以将森林中的每棵树的根结点看作是兄弟,由于每棵树都可以转换为二叉树,所以森林也可以转换为二叉树。
将森林转换为二叉树的步骤是:
(1)先把每棵树转换为二叉树;
(2)第一棵二叉树不动,从第二棵二叉树开始,依次把后一棵二叉树的根结点作为前一棵二叉树的根结点的右孩子结点,用线连接起来。当所有的二叉树连接起来后得到的二叉树就是由森林转换得到的二叉树。
森林转换为二叉树的转换过程示意图
3、二叉树转换为树
二叉树转换为树是树转换为二叉树的逆过程,其步骤是:
(1)若某结点的左孩子结点存在,将左孩子结点的右孩子结点、右孩子结点的右孩子结点……都作为该结点的孩子结点,将该结点与这些右孩子结点用线连接起来;
(2)删除原二叉树中所有结点与其右孩子结点的连线;
(3)整理(1)和(2)两步得到的树,使之结构层次分明。
二叉树转换为树的过程示意图
4、二叉树转换为森林
二叉树转换为森林比较简单,其步骤如下:
(1)先把每个结点与右孩子结点的连线删除,得到分离的二叉树;
(2)把分离后的每棵二叉树转换为树;
(3)整理第(2)步得到的树,使之规范,这样得到森林。
根据树与二叉树的转换关系以及二叉树的遍历定义可以推知,树的先序遍历与其转换的相应的二叉树的先序遍历的结果序列相同;树的后序遍历与其转换的二叉树的中序遍历的结果序列相同;树的层序遍历与其转换的二叉树的后序遍历的结果序列相同。由森林与二叉树的转换关系以及森林与二叉树的遍历定义可知,森林的先序遍历和中序遍历与所转换得到的二叉树的先序遍历和中序遍历的结果序列相同。
转载地址:点击打开链接
- 树、森林与二叉树相互转化原理图
- 二叉树与森林的转化
- 树、森林与二叉树的相互转换
- 树、森林与二叉树的相互转换
- 树、森林与二叉树的转化理解
- 树和森林的相互转化
- 二叉树、树、森林的相互转换
- 森林、树、二叉树的相互转换
- 树,森林,二叉树的相互转换
- 二叉树、树、森林之间转化
- 树、森林转化为二叉树
- 树、二叉树、森林之间的转化
- 二叉树、树、森林之间的转化
- C++森林转化为二叉树代码
- 森林和二叉树的转化
- 树型结构2 AVL 森林与二叉树转化 二叉链表三种遍历
- 树、森林与二叉树
- 树,森林及二叉树的相互转换
- 解决ADT大量出现"Unexpected value from nativeGetEnabledTags: 0"的问题
- 在maven项目中获取配置文件
- 素数筛法/埃拉托斯特尼筛法(sieve of Eratosthenes)——理解及具体问题
- CentOS 6.3 配置VNCServer 5.0.3
- 5-12聊天窗口
- 树、森林与二叉树相互转化原理图
- c++第三次作业
- C++内存泄漏的检测
- iOS部分知识点小结
- Objective-c 对象与类
- Flash如何插入到PowerPoint2003中
- 安卓开发与分析者的利器--安卓右键工具
- LeetCode114—Flatten Binary Tree to Linked List
- ImageSwitcher 滑动切换图片