前序、中序、后续构造二叉树?

栏目: 数据库 · 发布时间: 4年前

内容简介:前面分享了《每种遍历输出的就是一个序列。如果只给我们一个序列,我们是没办法反唯一的向构造出一个二叉树的。比如前序序列

一、背景

前面分享了《 二叉树就是这么简单 》,里面提到二叉树有三种遍历方式:前序遍历、中序遍历、后序遍历。

每种遍历输出的就是一个序列。如果只给我们一个序列,我们是没办法反唯一的向构造出一个二叉树的。

比如前序序列 [3,9,20,15,7] ,我们可以确定 3 是根,但是之后的就不知道哪个属于左子树,哪个属于右子树。

但是给我们一个中序序列和后序序列,我们就可以唯一的构造出一个二叉树了。

二、中序与后序

假设中序和后序的数据如下:

中序遍历 inorder = [9,3,15,20,7]
后序遍历 postorder = [9,15,7,20,3]

前序、中序、后续构造二叉树?

这里假设我们实现了一个函数,传入两个中序序列和后序序列,我们可以返回对应的二叉树。

第一步:根据后序序列最后一个位置,我们可以确定根是 postorder[4]=3

然后在中序序列中,查找到根的位置是 inorder[1]=3

第二步:根据中序序列根的位置,我们可以得到左子树的中序序列 [9] 和右子树的中序序列 [15,20,7]

接着,我们也可以根据两个子树的序列长度,得到左子树的后序序列 [9] 和右子树的后序序列 15,7,20

第三步:递归函数自身,分别得到左子树和右子树。

前序、中序、后续构造二叉树?

注意事项:这里有个特殊处理:如果序列为空,则返回空二叉树。

三、最后

对于中序和前序,其实是类似的方法,作为思考题留给大家吧。

另外再附加一道思考题:前序和后序能得到二叉树吗?为什么?

-EOF-


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

赛博人

赛博人

[美]约翰·苏勒尔 / 刘淑华、张海会 / 中信出版集团 / 2018-7 / 88.00

随着数字时代的飞速发展,网络空间正在深深影响着我们每个人的思想、感受和网络行为,其对我们的影响甚至比在现实生活中更大。为全面解析人类在网络空间中的感知、感觉、思维以及行为方式,帮助我们应对生活中面临的各种挑战,促进个人成长和改善心理健康,网络心理学专家和学科奠基人约翰·R.苏勒尔,根据20多年在不同网络环境里进行参与-观察式的实地调查所获得的成果,综合运用了行为心理学、认知心理学、人本主义心理学和......一起来看看 《赛博人》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具