题目:

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

分析:

根据二叉树的前序和中序遍历,重建二叉树。

我们知道:

前序遍历:根节点,左子树,右子树。

中序遍历:左子树,根节点,右子树。

后序遍历:左子树,右子树,根节点。

可以发现,前序遍历的第一个数便是整个数的根节点,而这个数在中序遍历中,又将数组分成两部分,其中左边便是左子树,右边是右子树,根据划分出来的左右子树,我们又可以返回前序遍历,去查看左右子树数组中的第一个元素,这样就可以递归求解这个问题了。

我们要记录好每次递归执行时的序列索引,这样有利于我们求解子问题需要数组的索引,前序遍历数组的左右索引记为leftPre,rightPre,中序遍历数组的左右索引是leftIn和rightIn。

则左子树的前序遍历数组左索引是leftPre+1,因为leftPre指的元素是root。

左子树的前序遍历数组右索引是leftPre+flag-leftIn,其中flag是root在中序遍历数组中的索引,而flag-leftIn正好是左子树元素的个数。

左子树的中序遍历数组索引是leftPre和flag-1,因为flag是我们找到的root元素,左边自然就是新的中序遍历数组了。

右子树的前序遍历数组左索引是leftPre+flag-leftIn+1,其实也就是左子树的右索引加1,因为在前序遍历中,左右子树是相连的。rightPre自然就成了右索引。

右子树的中序遍历数组索引是flag+1和rightIn。

不过在求解中,每次都要在中序遍历的数组中去查找根节点的索引,我们可以开始的时候将索引存进map中,需要的时候直接取,这样可以降低时间复杂度。

程序:

C++

class Solution {
public:
TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> vin) {
return helper(pre, vin, , pre.size()-, , vin.size()-);
}
TreeNode* helper(vector<int>& preorder, vector<int>& inorder, int leftPre, int rightPre, int leftIn, int rightIn){
if(leftPre > rightPre)
return nullptr;
TreeNode* root = new TreeNode(preorder[leftPre]);
if(leftPre == rightPre)
return root;
else{
int i = leftIn;
for(;i <= rightIn; ++i){
if(inorder[i] == preorder[leftPre])
break;
}
root->left = helper(preorder, inorder, leftPre+, leftPre+i-leftIn, leftIn, i-);
root->right = helper(preorder, inorder, leftPre+i+-leftIn, rightPre, i+, rightIn);
return root;
}
}
};

Java

//use HashMap
import java.util.HashMap;
public class Solution {
public TreeNode reConstructBinaryTree(int [] pre,int [] in) {
map = new HashMap<>();
for(int i = 0; i < in.length; ++i){
map.put(in[i], i);
}
return helper(pre, in, 0, pre.length-1, 0, in.length-1);
}
public TreeNode helper(int[] preorder, int[] inorder, int leftPre, int rightPre, int leftIn, int rightIn){
if(leftPre > rightPre)
return null;
TreeNode root = new TreeNode(preorder[leftPre]);
if(leftPre == rightPre)
return root;
else{
int i = map.get(preorder[leftPre]);
root.left = helper(preorder, inorder, leftPre+1, leftPre+i-leftIn, leftIn, i-1);
root.right = helper(preorder, inorder, leftPre+i-leftIn+1, rightPre, i+1, rightIn);
return root;
}
}
private HashMap<Integer, Integer> map;
}

剑指Offer-4.重建二叉树(C++/Java)的更多相关文章

  1. 剑指Offer:重建二叉树【7】

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

  2. 《剑指offer》重建二叉树

    本题来自<剑指offer> 重构二叉树 题目: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2 ...

  3. 【Java】 剑指offer(6) 重建二叉树

    本文参考自<剑指offer>一书,代码采用Java语言.  更多:<剑指Offer>Java实现合集 题目 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的 ...

  4. Go语言实现:【剑指offer】重建二叉树

    该题目来源于牛客网<剑指offer>专题. 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4 ...

  5. 剑指offer之重建二叉树

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

  6. 剑指OFFER之重建二叉树(九度OJ1385)

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

  7. 剑指offer:重建二叉树

    重建二叉树的前置知识: 0.遍历二叉树: (1)前序遍历:根左右 --> 先访问根节点,再前序遍历左子树,最后前序遍历右子树: (2)中序遍历:左根右 --> 先中序遍历左子树,再访问根节 ...

  8. 剑指Offer 4. 重建二叉树 (二叉树)

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

  9. 【剑指offer】重建二叉树

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

  10. 剑指offer——04重建二叉树(Python3)

    思路:在数据结构中,有一个条件反射,谈及二叉树,就递归.所以在实现重建二叉树时,也应该用到递归的思想. 在前序遍历中,根节点处于第一个:在中序遍历中,根节点的左边为左子树节点,根节点右边为右子树节点. ...

随机推荐

  1. jenkins下载插件无插件显示+离线下载插件方法

    1.打开Jenkins插件管理,可选插件为空,无法选择自己需要的插件进行下载 打开插件管理的“高级”选项,在升级站点填写 http://mirror.xmission.com/jenkins/upda ...

  2. LG1840 Color the Axis 线段树

    菜的人就要写简单题 为了练习手速来写这样一道 珂朵莉树 线段树简单题 没啥可说的,注意修改操作中要判一下 val=0 #include<bits/stdc++.h> using names ...

  3. angular路由事件

    Angular 4检测路由变化,可以使用router.events来监听: 支持的事件类型: NavigationStart:导航开始 NavigationEnd:导航结束 NavigationCan ...

  4. Java程序猿怎么才能月薪过万?

    每一个略微有点长进的人,都应该把作业里的前三名作为自己斗争的政策和对手.你离成为冠军Java程序员还有多远,看完这篇你就知道了. 软件工程师的作业生涯里,知识有一个三年的半衰期.这意味着三年后,你所具 ...

  5. python Qt5 实战(一)按钮颜色

    工作中,工具用到了python Qt5,涉及到了按钮颜色,这里就做个总结.也顺便给要用这块的同仁抛出来一个砖头,把大牛引出来做个指导. 一般设置按钮的颜色有三种表达:如下所示:具体的怎么使用,估计要看 ...

  6. 纯手打AJAX,还有一个对象转查询字符串的小方法obj=>url

    function json2url(json){ var arr=[]; for(var name in json){ arr.push(name+'='+json[name]); } return ...

  7. HTML+css基础 标签

    图片标签:<img src="./imgs/1.jpg" alt=“一种对图片解释说明的” /> HTML   超文本标记语言   英文名称: hyper  text  ...

  8. SqlServer ----- 拷贝数据表

    两种方式,第一种方式只是把表中的字段进行拷贝,第二种把表中的关联关系,主键自增长全部拷贝. 1.把表中的关联关系,主键自增长全部拷贝. 选择需要拷贝的表,点击编辑器窗口,会看到这个表的sql 语句,主 ...

  9. 使用码云,GitHub进行版本控制,并通过WebHook进行自动部署

    我们通常需要在 PUSH 代码到远程仓库时,线上环境会自动进行代码同步,这时候就需要用到WebHook,它会自动回调我们设定的http地址. 通过请求我们自已编写的脚本,来拉取代码,实现与远程仓库代码 ...

  10. JDK1.8新特性——Collector接口和Collectors工具类

    JDK1.8新特性——Collector接口和Collectors工具类 摘要:本文主要学习了在Java1.8中新增的Collector接口和Collectors工具类,以及使用它们在处理集合时的改进 ...