从http://www.cnblogs.com/fzhe/archive/2013/01/07/2849040.html处转载。

一、已知前序、中序遍历,求后序遍历

例:

前序遍历:         GDAFEMHZ

中序遍历:         ADEFGHMZ

画树求法:第一步,根据前序遍历的特点,我们知道根结点为G

第二步,观察中序遍历ADEFGHMZ。其中root节点G左侧的ADEF必然是root的左子树,G右侧的HMZ必然是root的右子树。

第三步,观察左子树ADEF,左子树的中的根节点必然是大树的root的leftchild。在前序遍历中,大树的root的leftchild位于root之后,所以左子树的根节点为D。

第四步,同样的道理,root的右子树节点HMZ中的根节点也可以通过前序遍历求得。在前序遍历中,一定是先把root和root的所有左子树节点遍历完之后才会遍历右子树,并且遍历的左子树的第一个节点就是左子树的根节点。同理,遍历的右子树的第一个节点就是右子树的根节点。

第五步,观察发现,上面的过程是递归的。先找到当前树的根节点,然后划分为左子树,右子树,然后进入左子树重复上面的过程,然后进入右子树重复上面的过程。最后就可以还原一棵树了。该步递归的过程可以简洁表达如下:

1 确定根,确定左子树,确定右子树。

2 在左子树中递归。

3 在右子树中递归。

4 打印当前根。

那么,我们可以画出这个二叉树的形状:

那么,根据后序的遍历规则,我们可以知道,后序遍历顺序为:AEFDHZMG

编程求法:(依据上面的思路,写递归程序)

 1 #include <stdio.h>
 2 #include <string.h>
 3
 4 void TreeSequence(char * pre , char  * order , int length )
 5 {
 6     if(0 == length)
 7     {
 8         return ;
 9     }
10
11     char data = * pre ;
12     int rootpos=0 ;
13     for( ;rootpos<length ; rootpos++)
14     {
15         if( * pre == order[rootpos])
16             break ;
17     }
18
19     TreeSequence(pre+1 ,order, rootpos) ;  //
20     TreeSequence(pre + rootpos + 1, order + rootpos +1, length-(rootpos+1)) ; //
21     printf("%c" ,data) ;
22
23 }
24
25 int main()
26 {
27     char str1[105],str2[105] ;
28     printf("请输入先序遍历的字符:") ;
29     scanf("%s" , str1) ;
30     printf("请输入中序遍历的字符:") ;
31     scanf("%s" , str2) ;
32     printf("输出后序遍历的字符:") ;
33     int length = strlen(str1) ;
34     TreeSequence( str1 , str2 , length) ;
35     printf("\n") ;
36 }

转载于:https://www.cnblogs.com/fengxmx/p/3726261.html

已知二叉树先序和中序,求后序。相关推荐

  1. C++实现已知二叉树前序遍历和中序遍历,求后序遍历

    C++实现已知二叉树前序遍历和中序遍历,求后序遍历 一.基本概念 1.先序遍历(NLR)可以确定二叉树的父子结点: 2.中序遍历(LNR)可以确定二叉树的左右子树: 3.后序遍历(LRN)可以确定二叉 ...

  2. 数据结构与算法:已知二叉树两种遍历序列,求第三种遍历序列

    在笔试题目中经常碰到此类题目,已知先序遍历序列和中序遍历序列,求后序序列或者已知中序序列和后序序列,求先序遍历序列.其中若已知先序序列和后序序列,无法唯一确定一棵树,所以就无法得知中序序列. 1.已知 ...

  3. 已知二叉树先序和中序遍历结果,求后序遍历结果

    以下面的例题为例进行讲解:已知一棵二叉树的先序遍历序列和中序遍历序列分别是ABDCEF.BDAECF,求二叉树及后序遍历序列. 分析:先序遍历序列的第一个字符为根结点.对于中序遍历,根结点在中序遍历序 ...

  4. 给出中序和前序求后序Java,已知二叉樹前序,中序遍歷,求后序遍歷,java實現...

    簡單介紹一下思想,先看前序,前序遍歷的第一個節點,就是該樹的根.在中序中找到該根的位置,設為index,在中序遍歷集合中,位於index之前的屬於根的左子樹,位於index之后的屬於根的右子樹.然后, ...

  5. 给定二叉树先序、中序遍历序列,求后序遍历

    给定一个二叉树的前序遍历和中序遍历的序列,输出对应这个二叉树的后续遍历序列. 输入描述: 输入为一行. 两个字符串,分别表示二叉树的前序遍历和中序遍历结果,用空格分隔.保证数据合法 输出描述: 对应输 ...

  6. 【算法】【树】已知先序中序序列求后序序列(详细解释)

    题目描述 如题所示,已知先序中序序列建树与求后序序列 算法原理 利用递归和分制的思想,找到当前树先序序列的根节点,然后找到对应中序序列的位置,然后根据根节点在中序序列中的位置来判断左右子树分别的位置, ...

  7. 已知前序中序,求后序

    已知二叉树的前序和中序,求其后序 例:前序(A B D G H C E I F J ) 中序(G D H B A E I C J F) 其后序为:G H D B I E J F C A 思路:先序的遍 ...

  8. 二叉树面试题:前中序求后序、中后序求前序

    在面试时,避免不了的会遇到一些数据结构的面试题,今天我们就来了解一下二叉树的经典面试题: 已知二叉树的前序遍历顺序为ABDCEGHF,中序遍历顺序为DBAGEHCF,求该二叉树的后序遍历. 还有: 已 ...

  9. 数据结构----二叉树已知先序和中序遍历序列求后序遍历

    说明 通过先序和中序或者中序和后序我们可以还原出原始二叉树,但是通过先序和后序是无法还原出原始二叉树也即是说,只有通过先序和中序,或者中序和后序我们才可以唯一的确定一个二叉树. 例子一 已知先序和中序 ...

  10. 已知二叉树的后序序列和中序序列,求先序序列。

    后续遍历=左子树,右子树,根,中序遍历=左子树,根,右子树 已知二叉树后序遍历序列是DBCEFGHA,中序遍历序列EDCBAHFG,它的前序遍历的序列是? 由后序遍历序列是DBCEFGHA,可以看出整 ...

最新文章

  1. 求二叉树上结点的路径_剑指offer 二叉树
  2. Spring boot重新编译
  3. UIViewController与UIView的关系
  4. Java内存运行机制
  5. phabricator安装配置和使用(docker安装和独立部署)
  6. FL studio 20简易入门教程 -- 第六篇 -- 调音台和自动化包络线
  7. 使用python脚本抢购天猫和淘宝商品,0秒下单
  8. testcenter自动化
  9. Android studio学习笔记:adb被系统空闲进程占用了怎么办?
  10. 怎么判断两个多项式互素_多项式互素性质的补充讨论
  11. php writeup,writeup---你真的会PHP吗?
  12. webview加载html图片不显示图片,WebView加载网页不显示图片解决办法
  13. 英孚教育全面上云与Serverless构建之路
  14. 不只是包子铺!巴比食品:重回高增长赛道,做中式面点第一品牌
  15. 浅谈产业界与学术界的合作研究(转)
  16. drozer安装与使用
  17. 深度学习——模型调整
  18. html5网站上线模版,HTML5网站即将上线前端模板
  19. 购房从银行贷了一笔款d,准备每个月还款额为p,月利率为r,计算多少月能还清。设d为300000,p为6000元,r为1%
  20. ULTRON — 360基于Flink的实时数仓平台

热门文章

  1. dio设置自定义post请求_Flutter用dio封装http网络请求,设置统一的请求地址、headers及处理返回内容...
  2. Pytorch tensor基础知识
  3. java ee自学_自学JavaEE难度大不大?
  4. 拖动获取元素_如何使用HTML5实现多个元素的拖放功能
  5. java 计划任务_Java实现定时任务的几种方案
  6. 自动驾驶 8-3: 递归最小二乘法Recursive Least Squares
  7. TensorFlow by Google CNN卷积神经网络 Machine Learning Foundations: Ep #3 - Convolutions and pooling
  8. AWS AI网络研讨会 webinar - Case 分享
  9. java 实际参数列表_JAVA实际参数和形式参数列表长度不同
  10. CART分类树算法的最优特征选择