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

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

为了解决这个问题,我们需要根据给定的前序遍历和中序遍历结果,重建一个二叉树。前序遍历和中序遍历都是递归的结果,我们可以利用这些结果来确定二叉树的结构。

方法思路

  • 问题分析

    • 前序遍历结果是 [root, left, right],表示根节点访问后,先访问左子树,最后访问右子树。
    • 中序遍历结果是 [left, root, right],表示先访问左子树,接着访问根节点,最后访问右子树。
    • 给定这些结果,我们可以确定每个节点的位置。
  • 关键思路

    • 使用递归来构建树。
    • 每次递归调用时,确定当前根节点的位置,然后分割左右子树。
    • 使用哈希表记录中序遍历中每个节点的位置,以便快速查找。
  • 算法步骤

    • 创建一个递归函数,参数包括当前前序遍历的索引 i,中序遍历的左边界 left 和右边界 right
    • 在函数内部,找到当前根节点在中序遍历中的位置 j
    • 分别构建左子树和右子树,递归调用左子树和右子树的构建函数。
    • 返回构建好的根节点。
  • 解决代码

    import java.util.HashMap;import java.util.Map;class TreeNode {    int val;    TreeNode left;    TreeNode right;    TreeNode(int x) {        val = x;    }}public 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 < preorder.length; i++) { hashmap.put(inorder[i], i); } return recur(0, 0, inorder.length - 1); } private TreeNode recur(int i, int left, int right) { if (left > right) { return null; } int j = hashmap.get(preorder[i]); TreeNode root = new TreeNode(preorder[i]); root.left = recur(i + 1, left, j - 1); root.right = recur(i + (j - left) + 1, j + 1, right); return root; }}

    代码解释

    • TreeNode 类:定义了二叉树的节点,包含值、左子树和右子树。
    • buildTree 方法:初始化时,建立哈希表记录中序遍历中每个节点的位置,并调用递归函数构建树。
    • recur 方法:递归函数,根据当前前序索引 i 和中序左右边界 leftright 构建树。
      • 检查边界条件,返回 null 若无子树。
      • 找到当前根节点在中序中的位置 j
      • 分别构建左子树和右子树,递归调用函数。
      • 返回当前根节点。

    这种方法利用了前序和中序遍历的特点,通过递归和哈希表高效地重建二叉树,确保了算法的正确性和效率。

    转载地址:http://vbftz.baihongyu.com/

    你可能感兴趣的文章
    npm错误 gyp错误 vs版本不对 msvs_version不兼容
    查看>>
    npm错误Error: Cannot find module ‘postcss-loader‘
    查看>>
    npm,yarn,cnpm 的区别
    查看>>
    NPOI之Excel——合并单元格、设置样式、输入公式
    查看>>
    NPOI初级教程
    查看>>
    NPOI利用多任务模式分批写入多个Excel
    查看>>
    NPOI在Excel中插入图片
    查看>>
    NPOI将某个程序段耗时插入Excel
    查看>>
    NPOI格式设置
    查看>>
    NPOI设置单元格格式
    查看>>
    Npp删除选中行的Macro录制方式
    查看>>
    NR,NF,FNR
    查看>>
    nrf24l01+arduino
    查看>>
    nrf开发笔记一开发软件
    查看>>
    nrm —— 快速切换 NPM 源 (附带测速功能)
    查看>>
    nrm报错 [ERR_INVALID_ARG_TYPE]
    查看>>
    NS3 IP首部校验和
    查看>>
    NSDateFormatter的替代方法
    查看>>
    NSError 的使用方法
    查看>>
    nsis 安装脚本示例(转)
    查看>>