博客
关于我
剑指offer笔记 07.给出二叉树的前序遍历和中序遍历,重建该二叉树
阅读量:585 次
发布时间:2019-03-11

本文共 1864 字,大约阅读时间需要 6 分钟。

剑指offer笔记 06.从尾到头打印链表 C++实现

剑指offer笔记 07.给出二叉树的前序遍历和中序遍历,重建该二叉树

1.题目描述

输入某二叉树的前序遍历和中序遍历的结果,请重建该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。

给出:前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7]返回如下的二叉树:   3   / \  9  20    /  \   15   7

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2.解答思路

1.前序遍历 [root | left | right],递归中用 i 表示索引

中序遍历 [left | root | right],递归中用 j 表示索引
2.
递归的参数有三个:

  • i 表示根节点在preorder中的索引
  • left 表示以索引为 i 的节点为根节点的子树在inorder中的左边界索引
  • right 表示以索引为 i 的节点为根节点的子树在inorder中的右边界索引
  • 需要根据preorder中的根节点值定位其在inorder中的位置 j,以此确定左右子树的索引范围,因此需要用哈希表hashmap记录一下每个节点值对应的在inorder中的索引
  • 进入递归后,先创建根节点,读取根节点在inorder中的索引 j ,再创建左右子节点,进入递归:
    i. 左子树中的根节点索引为 i + 1,左边界索引为 left,右边界索引为 j - 1
    ii. 右子树中的根节点索引为 根节点索引 + 左子树长度 + 1 = i + (j - left) + 1,左边界索引为 j + 1,右边界索引为 right
  • 返回根节点root

作者:edelweisskoko

链接:https://leetcode-cn.com/problems/zhong-jian-er-cha-shu-lcof/solution/jian-zhi-offer-07-zhong-jian-er-cha-shu-2j9vf/
来源:力扣(LeetCode) 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

3.知识要点

  • 建立哈希索引
private Map
hashmap = new HashMap<>();
  • 把中序遍历放入哈希索引中:
for(int i =0;i
  • 构建一颗以preorder[i]为根节点的树:
TreeNode root=new TreeNode(preorder[i]);

4.java代码

/** * Definition for a binary tree node. * public class TreeNode { *     int val; *     TreeNode left; *     TreeNode right; *     TreeNode(int x) { val = x; } * } */class Solution {      private Map
hashmap = new HashMap<>(); private int[] preorder; public TreeNode buildTree(int[] preorder, int[] inorder) { this.preorder=preorder; for(int i=0;i
right){ return null; } TreeNode root=new TreeNode(preorder[i]);//定义一颗以preorder[0]树根的树 int j=hashmap.get(preorder[i]);//找到树根root在中序遍历中的位置 root.left=recur(i+1,left,j-1); root.right=recur(i-left+j+1,j+1,right); return root; } }
你可能感兴趣的文章
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(72)——MySQL 开发者开发,设计规范再总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(74)——慢SQL!压垮团队的最后一根稻草!
查看>>
Mysql学习总结(75)——并发量大、数据量大的互联网业务数据库设计军规
查看>>
Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>