Movatterモバイル変換


[0]ホーム

URL:


根据二叉树的前序和中序求后序

最新推荐文章于 2025-10-22 21:00:50 发布
原创最新推荐文章于 2025-10-22 21:00:50 发布·3.8w 阅读
· 9
· 44·
CC 4.0 BY-SA版权
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。
本文介绍了一种根据二叉树的前序和中序遍历结果,推导出后序遍历结果的方法,并提供了C语言的具体实现。通过递归构建二叉树,最终输出后序遍历结果。

在面试的过程中,发现有几家公司都喜欢考这样的一道题,就是在一棵二叉树中,已知这棵二叉树的前序和中序遍历结果,要求写出后序遍历结果。

例如:在一棵二叉树总,前序遍历结果为:ABDGCEFH,中序遍历结果为:DGBAECHF,求后序遍历结果。

我们知道:

前序遍历方式为:根节点->左子树->右子树

中序遍历方式为:左子树->根节点->右子树

后序遍历方式为:左子树->右子树->根节点

从这里可以看出,前序遍历的第一个值就是根节点,然后再中序遍历中找到这个值,那么这个值的左边部分即为当前二叉树的左子树部分前序遍历结果,这个值的右边部分即为当前二叉树的右子树部分前序遍历结果。因此,通过这个分析,可以恢复这棵二叉树,得到这样的一段伪码:

 

节点 getRoot(前序,中序)

c=前序第一个字符

pos=c在中序中的位置

len1=中序pos左半部分长度

len2=中序pos右半部分长度

新建节点r,令r的元素等于c

r的左儿子=getRoot(前序位置1开始的len1长度部分,中序pos位置的左半部分)

r的右儿子=getRoot(前序位置len1开始右半部分,中序pos位置的右半部分)

return r

 

如图1示:

图1

输入前序ABDGCEFH,中序DGBAECHF,可以得出

A为该二叉树的根节点

1: BDG为该二叉树左子树的前序

2: DGB为该二叉树左子树的中序

根据1和2可以构建一棵左子树

 

3: CEFH为该二叉树右子树的前序

4: ECHF为该二叉树右子树的中序

根据3和4可以构建一个右子树

 

执行至该步骤的时候就得到了该二叉树的云结构,如图2所示,A为根节点,BDG在它的左子树上,CEFG在它的右子树上。

如此递归即可以构建一棵完整的二叉树

图2

 

 

下面是c语言的实现方法(该代码的变量p1,p2,i1,i2,tmp请参考图1):

 

 

下面是输出结果显示:

确定要放弃本次机会?
福利倒计时
::

立减 ¥

普通VIP年卡可用
立即使用
3 条评论您还未登录,请先登录后发表或查看评论

1 条评论

  • cjs990204
    尘~客2021.10.11
    可以在详细讲一下过程吗
  • chenyiming_1990
    大米粒ing2013.05.18
    我觉的楼主的意思是在中序中这个值的位置坐标,在前序中这个坐标的左边部分即为当前二叉树的左子树部分前序遍历结果,这个值的右边部分即为当前二叉树的右子树部分前序遍历结果
  • zhu19774279
    zhu197742792013.04.16
    原文这一段话不对吧"从这里可以看出,前序遍历的第一个值就是根节点,然后再中序遍历中找到这个值,那么这个值的左边部分即为当前二叉树的左子树部分前序遍历结果,这个值的右边部分即为当前二叉树的右子树部分前序遍历结果。因此,通过这个分析,可以恢复这棵二叉树,得到这样的一段伪码: "我觉得应该是这样:从这里可以看出,前序遍历的第一个值就是根节点,然后在中序遍历中找到这个值,那么这个值的左边部分即为当前二叉树的左子树部分中序遍历结果,这个值的右边部分即为当前二叉树的右子树部分中序遍历结果。因此,通过这个分析,可以恢复这棵二叉树,得到这样的一段伪码:

博客等级

码龄19年
30
原创
91
点赞
203
收藏
140
粉丝
关注
私信

热门文章

分类专栏

展开全部收起

上一篇:
看Python应乎潮流的72变
下一篇:
Python练手之根据前序和中序&根据中序和后序重建二叉树,输出前序、中序和后序遍历结果

最新评论

大家在看

最新文章

目录

展开全部

收起

目录

展开全部

收起

上一篇:
看Python应乎潮流的72变
下一篇:
Python练手之根据前序和中序&根据中序和后序重建二叉树,输出前序、中序和后序遍历结果

目录

评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
查看更多评论
 条评论被折叠 查看
被折叠的  条评论为什么被折叠?到【灌水乐园】发言
查看更多评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值

[8]ページ先頭

©2009-2025 Movatter.jp