树,森林,二叉树之间的转换以及 树,森林的遍历

普通树转换为二叉树

1.树中的所有的兄弟节点之间加上一条线
2.对每个节点,除了保留与其长子的连线外,去掉该节点与其他孩子的连线。

将下图普通的树,转换为二叉树

在这里插入图片描述

1.树中的所有的兄弟节点之间加上一条线
在这里插入图片描述
2.对每个节点,除了保留与其长子的连线外,去掉该节点与其他孩子的连线。
在这里插入图片描述
经过简单转变:
在这里插入图片描述

森林转换为二叉树

1.现将森林中的每颗树转换为二叉树
2.再将各个二叉树的根节点视为兄弟从左到右连在一起,这样,形成了一颗二叉树

现将下图中的森林转换为二叉树

在这里插入图片描述

1.将森林中的每颗树转换为二叉树

在这里插入图片描述

2…将各个二叉树的根节点视为兄弟从左到右连在一起

在这里插入图片描述

形成二叉树
在这里插入图片描述

二叉树到树,森林之间的转换

和之前是逆序的

1.若节点x是其双亲y的左孩子,则把x的右孩子,右孩子的右孩子, . . . . . . 都与y连接起来。
2.去除所有双亲到右孩子之间的连线

如下图中的二叉树,
1.现有B符合第一点,将B的右孩子,右孩子的右孩子 . . . . . . 与A连接
在这里插入图片描述
在这里插入图片描述

2.去除所有双亲到右孩子之间的连线
在这里插入图片描述

树与森林的遍历

普通树的遍历
分为先根遍历和后根遍历
以下图为例:
先跟遍历:A B E C F D G H I

后跟遍历:E B F C G H I D A 在这里插入图片描述
森林的遍历也分为前序遍历和后序遍历,和树是一样的,只不过森林是树的集合。

我们进一步会发现:

树,森林的前跟遍历和二叉树的前序遍历结果相同
树,森林的后根遍历和二叉树的中序遍历结果相同

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值