在一棵二叉树总,前序遍历结果为: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在它的右子树上。

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

java代码

  1. class DataNode{
  2. int data;
  3. DataNode leftChild = null;
  4. DataNode rightChild = null;
  5. }
  6.  
  7. public class NodeTree {
  8.  
  9. DataNode rootNode;
  10. DataNode tempNode;
  11. //int index_root;
  12. DataNode left_childDataNode;
  13. DataNode right_childDataNode;
  14.  
  15. public DataNode initRootNode(int[] preArray){
  16. rootNode = new DataNode();
  17. rootNode.data = preArray[0];
  18. return rootNode;
  19. }
  20.  
  21. public void BuildTree(int[] preArray,int[] midArray,DataNode rootNode){
  22. int index_root = getIndex(midArray, rootNode.data);
  23. int lengthOfRightTree = preArray.length - index_root -1;
  24.  
  25. int[] preArray_left;
  26. int[] preArray_right;
  27. int[] midArray_left;
  28. int[] midArray_right;
  29.  
  30. if (index_root>0) {
  31. left_childDataNode = new DataNode();
  32. if (index_root==1) {
  33. left_childDataNode.data = midArray[0];
  34. rootNode.leftChild = left_childDataNode;
  35. }else {
  36. preArray_left = new int[index_root];
  37. midArray_left = new int[index_root];
  38. System.arraycopy(preArray, 1, preArray_left, 0, index_root);
  39. System.arraycopy(midArray, 0, midArray_left, 0, index_root);
  40. left_childDataNode.data = preArray_left[0];
  41. rootNode.leftChild = left_childDataNode;
  42. BuildTree(preArray_left, midArray_left, left_childDataNode);
  43. }
  44. }
  45.  
  46. if (lengthOfRightTree>0) {
  47. right_childDataNode = new DataNode();
  48. if (lengthOfRightTree==1) {
  49. right_childDataNode.data = midArray[index_root+1];
  50. rootNode.rightChild = right_childDataNode;
  51. return;
  52. }else {
  53. preArray_right = new int[lengthOfRightTree];
  54. midArray_right = new int[lengthOfRightTree];
  55. System.arraycopy(preArray, index_root+1, preArray_right, 0,lengthOfRightTree);
  56. System.arraycopy(midArray, index_root+1, midArray_right, 0, lengthOfRightTree);
  57. right_childDataNode.data = preArray_right[0];
  58. rootNode.rightChild = right_childDataNode;
  59. BuildTree(preArray_right, midArray_right,right_childDataNode);
  60. }
  61. }
  62. }
  63.  
  64. public int getIndex(int[] array,int temp){
  65. int index = -1;
  66. for (int i = 0; i < array.length; i++) {
  67. if (array[i]==temp) {
  68. index = i;
  69. return index;
  70. }
  71. }
  72. return index;
  73. }
  74. //后序遍历
  75. public void postOrderTraverse(DataNode node){
  76. if (node==null) {
  77. return;
  78. }
  79. postOrderTraverse(node.leftChild);
  80. postOrderTraverse(node.rightChild);
  81. System.out.print(node.data);
  82. }
  83. //前序遍历
  84. public void preOrderTraverse(DataNode node){
  85. if (node==null) {
  86. return;
  87. }
  88. System.out.print(node.data);
  89. preOrderTraverse(node.leftChild);
  90. preOrderTraverse(node.rightChild);
  91. }
  92. //中序遍历
  93. public void inOrderTraverse(DataNode node){
  94. if (node==null) {
  95. return;
  96. }
  97. inOrderTraverse(node.leftChild);
  98. System.out.print(node.data);
  99. inOrderTraverse(node.rightChild);
  100. }
  101.  
  102. public static void main(String args[]){
  103. int[] preArray = {1,2,3};
  104. int[] midArray = {1,2,3};
  105. NodeTree tree = new NodeTree();
  106. DataNode headNode = tree.initRootNode(preArray);
  107. tree.BuildTree(preArray, midArray, headNode);
  108. tree.postOrderTraverse(headNode);
  109. }
  110.  
  111. }

java 根据二叉树前序 ,中序求后续的更多相关文章

  1. hihocoder(第十周)二叉树(前序中序推后续)递推实现

    题目 : 后序遍历 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在参与过了美食节之后,小Hi和小Ho在别的地方又玩耍了一阵子,在这个过程中,小Ho得到了一个非常有意思 ...

  2. 【美国血统 American Heritage 题解】已知前序中序 求后序

    题目: 题目名称:美国血统 American Heritage 题目来源:美国血统 American Heritage ## 题目描述 农夫约翰非常认真地对待他的奶牛们的血统.然而他不是一个真正优秀的 ...

  3. 【11】-java递归和非递归二叉树前序中序后序遍历

    二叉树的遍历 对于二叉树来讲最主要.最基本的运算是遍历. 遍历二叉树 是指以一定的次序访问二叉树中的每个结点.所谓 访问结点 是指对结点进行各种操作的简称.例如,查询结点数据域的内容,或输出它的值,或 ...

  4. Tree Recovery(前序中序求后序)

    Tree Recovery Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 14640   Accepted: 9091 De ...

  5. HDU_1710_二叉树前序中序确定后序

    2018-3-6 按照王道机试书上的思路再做了一遍,先根据先序和中序建树,然后后序遍历. 静态分配数组用于建树,可以返回数组地址当作结点指针. #include<iostream> #in ...

  6. js二叉树,前序/中序/后序(最大最小值,排序)

    function Node(data,left,right) { this.left=left this.right=right this.data=data } function Btr() { t ...

  7. PAT (Advanced Level) 1136~1139:1136模拟 1137模拟 1138 前序中序求后序 1139模拟

    1136 A Delayed Palindrome(20 分) 题意:给定字符串A,判断A是否是回文串.若不是,则将A反转得到B,A和B相加得C,若C是回文串,则A被称为a delayed palin ...

  8. hdu 1701 (Binary Tree Traversals)(二叉树前序中序推后序)

                                                                                Binary Tree Traversals T ...

  9. Java 重建二叉树 根据前序中序重建二叉树

    题目:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2, ...

随机推荐

  1. 解决java使用Runtime.exec执行linux复杂命令不成功问题

    最近要实现一个Java调用一个复杂shell命令实现数据同步,该命令有管道重定向的语句,结果硬是执行不成功,而且也没异常报出.经过一段时间的折腾终于解决了此问题,权当做备忘记录下来(重点在红色框中的“ ...

  2. 优化Linux下的内核TCP参数以提高系统性能

    内核的优化跟服务器的优化一样,应本着稳定安全的原则.下面以64位的Centos5.5下的Squid服务器为例来说明,待客户端与服务器端建立 TCP/IP连接后就会关闭SOCKET,服务器端连接的端口状 ...

  3. python读取文件解码失败

    python2.7 urllib2 抓取新浪乱码 中的: 报错的异常是 UnicodeDecodeError: 'gbk' codec can't decode bytes in position 2 ...

  4. Linux上两种网络连接方式

    模式一:NAT方式好处:路由器更换,或者交换机更换,网络仍然可以使用,所用使用最多 准备工作: 查看VMware服务器启动情况,五个全开模式 vmnet8开启模式 1 配置VMware交换机的ip地址 ...

  5. 微信小程序 功能函数 获取验证码*

    yanZhengInput: function (e) { var that = this; var yanzheng = e.detail.value; var huozheng = this.da ...

  6. spring注解方式注入

    1.通过Resource注入 1.在属性上注入 1.默认注入 即不指定spring容器里面的名字 匹配规则:先通过属性的名字查找 再通过属性类型与实现类类型匹配查找 当有两个实现类会报错 2.通过指定 ...

  7. zabbix 自定义监控nginx

    zabbix自定义nginx监控项 查看nginx编译安装是否加上该选项,如果没有请重新编译安装 配置nginx.conf vim /usr/local/cpgroup/nginx/conf/vhos ...

  8. 【比赛】NOIP2017 列队

    一直忘了发,现在赶快补 用权值线段树维护有人的位置,动态开点省空间 多加的人用个vector存下来就可以了 #include<bits/stdc++.h> #define ui unsig ...

  9. 51nod 1571 最近等对 | 线段树 离线

    51nod 1571 最近等对 题面 现在有一个序列 a1, a2, ..., an ,还有m个查询 lj, rj (1 ≤ lj ≤ rj ≤ n) .对于每一个查询,请找出距离最近的两个元素 ax ...

  10. 【bzoj1026】 SCOI2009—windy数

    http://www.lydsy.com/JudgeOnline/problem.php?id=1026 (题目链接) 题意 在区间${[A,B]}$有多少个数相邻两个数位上的数之差至少为2. Sol ...