博客
关于我
剑指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/

    你可能感兴趣的文章
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    npm error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”。要解决此问题,1) 安装
    查看>>
    npm install digital envelope routines::unsupported解决方法
    查看>>
    npm install 报错 ERR_SOCKET_TIMEOUT 的解决方法
    查看>>
    npm install报错,证书验证失败unable to get local issuer certificate
    查看>>
    npm install无法生成node_modules的解决方法
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm run build报Cannot find module错误的解决方法
    查看>>
    npm run build部署到云服务器中的Nginx(图文配置)
    查看>>
    npm run dev 报错PS ‘vite‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。
    查看>>
    npm start运行了什么
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    NPM使用前设置和升级
    查看>>
    npm入门,这篇就够了
    查看>>
    npm切换到淘宝源
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm升级以及使用淘宝npm镜像
    查看>>
    npm发布自己的组件UI包(详细步骤,图文并茂)
    查看>>
    npm和yarn清理缓存命令
    查看>>
    npm和yarn的使用对比
    查看>>