二叉树

u010328107 2014-03-17 07:55:20
已知一个二叉树,前序遍历的节点顺序是ADCEFGHB,中续遍历的节点顺序是CDFEGHAB,请问后序遍历的节点顺序是多少?我的积分不多网见谅
...全文
205 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
__cc__ 2014-03-26
  • 打赏
  • 举报
回复
引用 5 楼 u010328107 的回复:
解答的很好
居然还没结贴
u010328107 2014-03-26
  • 打赏
  • 举报
回复
解答的很好
zhuyf87 2014-03-18
  • 打赏
  • 举报
回复
一步一步推导就可以了: 1、前序是ADCEFGHB,所以A是根节点 2、中续是CDFEGHAB,所以CDFEGH是A的左子树中的节点,右子树只有一个节点B 3、再看前序ADCEFGHB,组成根节点A的左子树的前序是DCEFGH,所以D是跟节点A的左子树的根节点 4、... 推导二叉树遍历结果
titer1 2014-03-18
  • 打赏
  • 举报
回复
引用 2 楼 NothingCanBeDone 的回复:
前:ADCEFGHB 中:CDFEGHAB 后:CFHGEDBA A D B C E F G H 前序列的根在前面,中序列的根在中间,所以中序的A之前的CDFEGH 为A的左子树,B为A的右子树; 由前序可知D应该为A的左子树的根节点; 由中序列可知,C在D的前面,所以C是D的左子树; 再回头看前序已经确定了前面3个的位置,所以第4个位置的E,必然是D的右子树的根节点; 剩下的3个节点,都应该是E的子节点或者子孙节点; 中序列里F在E的前面,必然F为E的左子树; 还有2个节点没有确定,可以肯定是E的右子树,前序中G在H的前面,表明G是H的根节点; 中序中G在H的后面,说明H是G的右子树。 由此整个序列分析完毕,可以构建二叉树,推到后续遍历。
呀真正的让我复习了 树的性质!
NothingCanBeDone 2014-03-17
  • 打赏
  • 举报
回复
前:ADCEFGHB 中:CDFEGHAB 后:CFHGEDBA A D B C E F G H 前序列的根在前面,中序列的根在中间,所以中序的A之前的CDFEGH 为A的左子树,B为A的右子树; 由前序可知D应该为A的左子树的根节点; 由中序列可知,C在D的前面,所以C是D的左子树; 再回头看前序已经确定了前面3个的位置,所以第4个位置的E,必然是D的右子树的根节点; 剩下的3个节点,都应该是E的子节点或者子孙节点; 中序列里F在E的前面,必然F为E的左子树; 还有2个节点没有确定,可以肯定是E的右子树,前序中G在H的前面,表明G是H的根节点; 中序中G在H的后面,说明H是G的右子树。 由此整个序列分析完毕,可以构建二叉树,推到后续遍历。
__cc__ 2014-03-17
  • 打赏
  • 举报
回复
前序遍历:ADCEFGHB 中序遍历:CDFEGHAB 后序遍历:CFHGEDBA  A  D  B C  E  F  G      H  

65,208

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧