由遍历序列构造二叉树

阅读: 评论:0

由遍历序列构造二叉树

由遍历序列构造二叉树

目录

前序遍历 + 中序遍历序列

后序+中序遍历序列

层序遍历+中序遍历序列


若只给出一棵二叉树的前/中/后/层 序遍历序列的一种,不能唯一确定一棵二叉树

 

前序遍历 + 中序遍历序列

 前序遍历:根结点、前序遍历左子树,前序遍历右子树

 中序遍历:中序遍历左子树,根结点,中序遍历右子树

 例子

(图有问题,绿色的点应该是c) 

 我们分析前序遍历第一个出现的结点一定为根结点,所以A为根结点,而中序遍历左边一定为左子树遍历的序列即BDC,右边右子树为E。

 而同样的道理看BDC的话,由前序排列知D为根结点,由中序遍历知左子树为B,右子树为E。


后序+中序遍历序列

后序遍历: 前序遍历左子树 、 前序遍历右子树、根节点

 中序遍历:中序遍历左子树,根结点,中序遍历右子树

例子

 我们看这个题目后序遍历最右边为根结点,由中序遍历 可分为 左:EAF   右:HCBGI

看左边的序列 EAF ,而在后序遍历那为EFA,可知A为“根结点”,左:E   右:F

看右边的序列HCBGI,前序遍历那为HCIGB,可知B为“根结点”,左:HC  右:GI

最后可知 H在左,C在右,G在左 ,I 在右


层序遍历+中序遍历序列

 开始时知道D在层序序列为第一个遍历所以,D为根结点,左子树:EAF,右子树:HCBGI

 之后由中序遍历层序遍历知A为左子树的根结点,B为右子树的根结点,然后不难知A的左孩子为   E,右孩子为F。

由层序遍历知,EF后面为CG所以它俩在中间,C 和 G 分别在中间,在看中序遍历序列
C的左边挂H,G的右边挂I

本文发布于:2024-01-29 17:45:50,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170652155317188.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:遍历   序列   二叉树
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23