2024.2.21力扣每日一题——从中序和后序遍历序列构建二叉树

2024.2.21

      • 题目来源
      • 我的题解
        • [方法一 递归方式](#方法一 递归方式)
        • [方法二 迭代方式](#方法二 迭代方式)

题目来源

力扣每日一题;题序:106

我的题解

方法一 递归方式
  • 后序特点:[ [左子树的前序遍历结果], [右子树的前序遍历结果],根节点 ]
  • 中序特点:[ [左子树的中序遍历结果], 根节点, [右子树的中序遍历结果] ]
    发现后序遍历的数组最后一个元素代表的即为根节点。知道这个性质后,我们可以利用已知的根节点信息在中序遍历的数组中找到根节点所在的下标,然后根据其将中序遍历的数组分成左右两部分,左边部分即左子树,右边部分为右子树,针对每个部分可以用同样的方法继续递归下去构造。
    时间复杂度 :O( n 2 n^2 n2)
    空间复杂度:O(n)
java 复制代码
public TreeNode buildTree(int[] inorder, int[] postorder) {
    return createTree(inorder,postorder,0,inorder.length-1,0,postorder.length-1);
}
public TreeNode createTree(int[] inorder, int[] postorder,int iL,int iR,int pL,int mid){
    if(iL>iR||pL>mid)
        return null;
    int val=postorder[mid];
    TreeNode root=new TreeNode(val);
    int index=find(inorder,val,iL,iR);
    int left=index-iL;
    int right=iR-index;
    root.left=createTree(inorder,postorder,iL,index-1,pL,mid-right-1);
    root.right=createTree(inorder,postorder,index+1,iR,mid-right,mid-1);
    return root;
}

public int find(int[] inorder,int val,int iL,int iR){
    int index=iL;
    for(int i=iL;i<=iR;i++){
        if(inorder[i]==val){
            index=i;
        }
    }
    return index;
}

在中序遍历中对根节点进行定位时,需要频繁扫描整个中序遍历的结果并找出根节点,时间复杂度较高。可以考虑使用哈希表来帮助快速地定位根节点。在此后构造二叉树的过程中,就只需要 O(1)的时间对根节点进行定位了。

java 复制代码
//使用哈希表优化
public TreeNode buildTree(int[] inorder, int[] postorder) {
    Map<Integer,Integer> map=new HashMap<>();
    for(int i=0;i<inorder.length;i++){
        map.put(inorder[i],i);
    }
    return createTree(inorder,postorder,0,inorder.length-1,0,postorder.length-1,map);
}
public TreeNode createTree(int[] inorder, int[] postorder,int iL,int iR,int pL,int mid,Map<Integer,Integer> map){
    if(iL>iR||pL>mid)
        return null;
    int val=postorder[mid];
    TreeNode root=new TreeNode(val);
    int index=map.get(val);
    int left=index-iL;
    int right=iR-index;
    root.left=createTree(inorder,postorder,iL,index-1,pL,mid-right-1,map);
    root.right=createTree(inorder,postorder,index+1,iR,mid-right,mid-1,map);
    return root;
}
方法二 迭代方式

官方题解,我还没搞明白!!!!

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
攒了一袋星辰几秒前
今日指数项目项目集成RabbitMQ与CaffienCatch
java·分布式·rabbitmq
wrx繁星点点7 分钟前
事务的四大特性(ACID)
java·开发语言·数据库
IT学长编程14 分钟前
计算机毕业设计 Java酷听音乐系统的设计与实现 Java实战项目 附源码+文档+视频讲解
java·spring boot·毕业设计·课程设计·毕业论文·音乐系统·计算机毕业设计选题
IT学长编程31 分钟前
计算机毕业设计 基于协同过滤算法的个性化音乐推荐系统的设计与实现 Java实战项目 附源码+文档+视频讲解
java·spring boot·毕业设计·毕业论文·协同过滤算法·计算机毕业设计选题·个性化音乐推荐系统
希望有朝一日能如愿以偿33 分钟前
力扣题解(飞机座位分配概率)
算法·leetcode·职场和发展
小小娥子36 分钟前
Redis的基础认识与在ubuntu上的安装教程
java·数据库·redis·缓存
Espresso Macchiato40 分钟前
Leetcode 3306. Count of Substrings Containing Every Vowel and K Consonants II
leetcode·滑动窗口·leetcode medium·leetcode 3306·leetcode周赛417
几何心凉44 分钟前
已解决:org.springframework.web.HttpMediaTypeNotAcceptableException
java
丶Darling.44 分钟前
代码随想录 | Day26 | 二叉树:二叉搜索树中的插入操作&&删除二叉搜索树中的节点&&修剪二叉搜索树
开发语言·数据结构·c++·笔记·学习·算法
华农第一蒟蒻1 小时前
Java中JWT(JSON Web Token)的运用
java·前端·spring boot·json·token