算法笔记:力扣105从前序与中序遍历序列构造二叉树

首先重要的是要明白前序遍历,和中序遍历的含义;

  • 前序遍历:根左右
  • 中序遍历:左根右

那么在前序遍历的数组中,第一位一定是根节点,而中序遍历数组中,根节点的左边部分就是该节点的左子树,右边部分就是右子树。

按照这个逻辑,就可以进行递归切分数组。

关键API:

Arrays.copyOfRange(),返回指定索引范围的数组。

代码:

因为每一个递归子树的根节点,都是前序数组的首个元素,所以就是不断递归前序数组,然后拿到每一个递归数组的首个元素,也就是根节点,然后在中序遍历中找到位置然后不断切分两个数组。

复制代码
class Solution {
    public TreeNode buildTree(int[] preorder, int[] inorder) {
            //前序遍历: 根左右
            //中序遍历: 左根右
            if(preorder.length==0||inorder.length==0){
                return null;
            }

            if(inorder.length==1){
                return new TreeNode(inorder[0]);
            }

            //首先前序遍历的第一个元素 肯定是根节点 那么找到根节点后
            //在中序遍历的数组中找到根节点   那么根节点的左边部分就是根节点的左子树  右边部分就是根节点的右子树
            int rootv=preorder[0]; //根节点
            int index=0; //根节点索引 
            for(int i=0;i<inorder.length;i++){
                if(rootv==inorder[i]){
                    //记录当前的根节点索引
                    index=i;
                    break;
                }
            }//到此已经在中序遍历数组中找到根节点 然后分为两部分
            //接下来就是递归数组确定元素
            TreeNode root=new TreeNode(rootv);

            //然后中序遍历数组就可以 左右子树范围可以找到 然后到前序遍历中找到对应的子树范围
            int []sonleft=Arrays.copyOfRange(inorder,0,index); //左子树
            int []sonright=Arrays.copyOfRange(inorder,index+1,inorder.length);;//右子树
            //然后在前序遍历中找到对应的数组范围
            int []qianleft=Arrays.copyOfRange(preorder,1,sonleft.length+1);//前序遍历 左子树部分
            int []qianright=Arrays.copyOfRange(preorder,sonleft.length+1,preorder.length);    //右子树部分 

            root.left=buildTree(qianleft,sonleft);
            root.right=buildTree(qianright,sonright);
            return root;
            

    }
   
}
相关推荐
落羽的落羽34 分钟前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler011 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
qq7422349841 小时前
从“感知”到“决断”:测评百度伐谋产业决策智能体的端到端推理与行动机制
人工智能·算法·百度·大模型·运筹优化
中屹指纹浏览器1 小时前
指纹浏览器环境克隆、批量派生的风控隐患剖析与标准化新建环境实操指南
经验分享·笔记
.千余2 小时前
【C++】C++手写Vector容器:从底层源码模拟实现
开发语言·c++·经验分享·笔记·学习
元直数字电路验证2 小时前
云计算实验笔记(四):容器编排(Container Orchestration)
运维·笔记·docker·云计算
huohaiyu2 小时前
深入解析Java垃圾回收机制
java·开发语言·算法·gc
浮芷.2 小时前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
装不满的克莱因瓶2 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion2 小时前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论