public class Order { int findPosInInOrder(String str,String in,int position){ char c = str.charAt(position); int length = in.length(); for(int i=0;i<length;i++){ if(c==in.charAt(i)) return i; } return -1; } /** * 已知前序和中序,求后序 * @param preOrder * @para…
参考:二叉树--前序和中序得到后序 思路历程: 在最初敲的时候,经常会弄混preorder和midorder的元素位置.大体的思路就是在preorder中找到根节点(根节点在序列的左边),然后在midorder中找到根节点的位置index,中序序列在index左边的部分就是root的左子树,在index右边的部分就是root的右子树,接着进行递归即可. 在实现的过程中,经常会纠结一个父亲只有一个儿子的时候儿子是左儿子还是右儿子的问题,最后也通过特判root的位置解决了,但是容易混乱. 于是喂了度…
题目链接 题目大意: 输入二叉树的前序.中序遍历,请输出它的后序遍历 #include <stdio.h> #include <string.h> ; // 长度为n s1 前序 s2 中序 构造后序s3 void build(int n, char * s1, char * s2, char * s3) { ) return; ]) - s2; //找到根节点在中序遍历中的位置 build(p, s1 + , s2, s3); //递归左子树的后序遍历 build(n - p -…
http://acm.hdu.edu.cn/showproblem.php?pid=1710 Binary Tree Traversals Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 4210    Accepted Submission(s): 1908 Problem Description A binary tree is a…
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1710 解题思路:可以由先序和中序的性质得到 : 先序的第一个借点肯定是当前子树的根结点, 那么在 中序中找到这个结点, 则这个结点左边的节点属于左子树, 右边的属于右子树.然后递归遍历就可以了. 样例: 9 1 2 4 7 3 5 8 9 6 4 7 2 1 8 5 9 3 6   7 4 2 8 9 5 6 3 1 如图:   因此,用深搜就能轻松解决了,注意DFS中的变量,以及向清楚DFS的条件…
#include"iostream" using namespace std; int pre[30]; int in[30]; int post[30]; int indexOfRootIn(int start,int stop,int root){ for(int j=start;j<=stop;j++){ if(in[j]==root){ return j; } } return -1; } void postOrder(int pre_start,int pre_end,…
描述 在数据结构中,遍历是二叉树最重要的操作之一.所谓遍历(Traversal)是指沿着某条搜索路线,依次对树中每个结点均做一次且仅做一次访问. 这里给出三种遍历算法. 1.中序遍历的递归算法定义:    若二叉树非空,则依次执行如下操作:         (1)遍历左子树:         (2)访问根结点:         (3)遍历右子树.2.前序遍历的递归算法定义:   若二叉树非空,则依次执行如下操作:         (1) 访问根结点:         (2) 遍历左子树:    …
知前序遍历与中序遍历 求后序遍历 #include<iostream> #include<cstring> #include<queue> #include<cstdio> using namespace std; bool fist; ; struct tree_node { int value; tree_node* leftchild; tree_node* rightchild; tree_node() { leftchild=NULL; right…
题目: 题目名称:美国血统 American Heritage 题目来源:美国血统 American Heritage ## 题目描述 农夫约翰非常认真地对待他的奶牛们的血统.然而他不是一个真正优秀的记帐员.他把他的奶牛 们的家谱作成二叉树,并且把二叉树以更线性的"树的中序遍历"和"树的前序遍历"的符号加以记录而 不是用图形的方法. 你的任务是在被给予奶牛家谱的"树中序遍历"和"树前序遍历"的符号后,创建奶牛家谱的"…
leetcode 105题,由树的前序序列和中序序列构建树结构.详细解答参考<剑指offer>page56. 先序遍历结果的第一个节点为根节点,在中序遍历结果中找到根节点的位置.然后就可以将问题拆分,递归求解. /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(N…