剑指Offer07 重建二叉树】的更多相关文章

题目: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回. 分析: 根据二叉树的前序和中序遍历,重建二叉树. 我们知道: 前序遍历:根节点,左子树,右子树. 中序遍历:左子树,根节点,右子树. 后序遍历:左子树,右子树,根节点. 可以发现,前序遍历的第一个数便是整个数的根节点,而这个数在中序遍历中,又将数组分成两…
   总结:    重建二叉树:其实就是根据前序和中序重建得到二叉树,得到后续,只要输出那边设置输出顺序即可 [编程题]重建二叉树 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回.   完整通过代码: 先新建一个二叉树的类 public class TreeNode { int val; TreeNode le…
题目:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回. 思路:1. 前序遍历首位是根节点,找到根节点之后,根据中序遍历找到左右子树 2. 把找到的根节点从pre里删除,分别找到1中的左右子树, preleft preright vinleft vinright 3. 然后左右子树带入1中 /* function…
题目描述: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回. 分析: 二叉树前序遍历的第一个值是根节点的值,从中序遍历中找到该值则可以从中序遍历中分开左子树和右子树.继续对左子树和右子树的遍历序列进行查找分割,递归该步骤就可以得到整棵二叉树. 代码: /** * Definition for binary tr…
Question 输入某二叉树的后序遍历和中序遍历的结果,请重建出该二叉树.假设输入的后序遍历和中序遍历的结果中都不含重复的数字.例如输入后序遍历序列{1, 3, 4, 2}和中序遍历序列{1, 2, 3, 4},则重建二叉树并返回. Solution 这道题跟中序和先序重建二叉树差不多,不同之处,就在于坐标的开始位置,以及后序遍历的最后一个节点是根节点. Code /** * Definition for a binary tree node. * struct TreeNode { * in…
先序:根>左>右 中序:左>根>右 后序:左>右>根 e.g. {1,2,4,7,3,5,6,8} {4,7,2,1,5,3,8,6} 先序第一个元素是根节点,在中序中找到后,中序左边的是左子树,右边是右子树 ---------------------------------------------------------------------------------------------------- 时间限制:1秒 空间限制:32768K 热度指数:571383…
题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回. 牛客网链接 js代码 /* function TreeNode(x) { this.val = x; this.left = null; this.right = null; } */ function reConstructBinaryTree(pr…
代码有问题 /************************************************************************* > File Name: 04_Rebuild_BinaryTree.c > Author: Juntaran > Mail: JuntaranMail@gmail.com > Created Time: 2016年08月29日 星期一 16时32分35秒 *********************************…
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 /**  * Definition for binary tree  * struct TreeNode {  *     int val;  *     TreeNode *left;  *     TreeNode *right;  *     Tr…
本题来自<剑指offer>二叉树的镜像 题目: 操作给定的二叉树,将其变换为源二叉树的镜像. 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ / \ 11 9 7 5 思路:   关于树,如果思路不够明确,可以画出图标辅助理解题目. 画出几步就会得出通用的思路,镜像发现如果通过交换左右子节点,左子树又是树,右子树又是树.可以采用递归的思路. 递归需要找到结束条件,如果根节点是是空或者当为子节点时候便结束本次递归. C…