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

    你可能感兴趣的文章
    nginx 常用配置记录
    查看>>
    Nginx 我们必须知道的那些事
    查看>>
    Nginx 的 proxy_pass 使用简介
    查看>>
    Nginx 的配置文件中的 keepalive 介绍
    查看>>
    Nginx 负载均衡与权重配置解析
    查看>>
    Nginx 负载均衡详解
    查看>>
    nginx 配置 单页面应用的解决方案
    查看>>
    nginx 配置https(一)—— 自签名证书
    查看>>
    nginx 配置~~~本身就是一个静态资源的服务器
    查看>>
    Nginx 配置解析:从基础到高级应用指南
    查看>>
    Nginx下配置codeigniter框架方法
    查看>>
    nginx添加模块与https支持
    查看>>
    Nginx用户认证
    查看>>
    Nginx的Rewrite正则表达式,匹配非某单词
    查看>>
    Nginx的使用总结(一)
    查看>>
    Nginx的可视化神器nginx-gui的下载配置和使用
    查看>>
    Nginx的是什么?干什么用的?
    查看>>
    Nginx访问控制_登陆权限的控制(http_auth_basic_module)
    查看>>
    nginx负载均衡器处理session共享的几种方法(转)
    查看>>
    nginx负载均衡的5种策略(转载)
    查看>>