内容简介:前面分享了《每种遍历输出的就是一个序列。如果只给我们一个序列,我们是没办法反唯一的向构造出一个二叉树的。比如前序序列
一、背景
前面分享了《 二叉树就是这么简单 》,里面提到二叉树有三种遍历方式:前序遍历、中序遍历、后序遍历。
每种遍历输出的就是一个序列。如果只给我们一个序列,我们是没办法反唯一的向构造出一个二叉树的。
比如前序序列 [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-
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 昨天的后续。。。
- 电子纸时钟的一些后续
- 送书走一波 | 微服务直播后续..
- 万豪国际泄露事件后续——简单调查分析与建议
- 2600万TRX被盗背后的罗生门 后续
- Holochain创始人总结:胜利、失误以及后续
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C程序设计语言
(美)Brian W. Kernighan、(美)Dennis M. Ritchie / 徐宝文、李志译、尤晋元审校 / 机械工业出版社 / 2004-1 / 30.00元
在计算机发展的历史上,没有哪一种程序设计语言像C语言这样应用广泛。本书原著即为C语言的设计者之一Dennis M.Ritchie和著名计算机科学家Brian W.Kernighan合著的一本介绍C语言的权威经典著作。我们现在见到的大量论述C语言程序设计的教材和专著均以此书为蓝本。原著第1版中介绍的C语言成为后来广泛使用的C语言版本——标准C的基础。人们熟知的“hello,World"程序就是由本书......一起来看看 《C程序设计语言》 这本书的介绍吧!