JAVA练习69- 从前序与中序遍历序列构造二叉树
创始人
2024-05-29 01:09:00
0

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:

3月5日练习内容


提示:以下是本篇文章正文内容,下面案例可供参考

一、题目-从前序与中序遍历序列构造二叉树

1.题目描述

给定两个整数数组 preorder 和 inorder ,其中 preorder 是二叉树的先序遍历, inorder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。

示例 1:

输入: preorder = [3,9,20,15,7], inorder = [9,3,15,20,7]
输出: [3,9,20,null,null,15,7]

示例 2: 

输入: preorder = [-1], inorder = [-1]
输出: [-1]

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/construct-binary-tree-from-preorder-and-inorder-traversal
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2.思路与代码

2.1 思路

1.根据传入数组数据创建相对应的集合

2.创建makeTree方法用于递归创建树

3.判断中序遍历的集合是否为空,为空则输出null;

4.由于前序遍历第一个结点为根结点,则提取第一个数创建根结点

5.查找根结点在中序遍历中的位置,并将中序遍历数组进行左右子树切分,用于递归建树

2.2 代码

代码如下(示例):

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public TreeNode buildTree(int[] preorder, int[] inorder) {//创建集合List preList = new ArrayList<>();List inList = new ArrayList<>();//将数组元素放入集合for(int i = 0;i < preorder.length;i ++){preList.add(preorder[i]);inList.add(inorder[i]);}return makeTree(preList,inList);}//建树public TreeNode makeTree(List preList,List inList){if(inList.size() == 0){return null;}//前序遍历第一为数字为根结点int rootVal = preList.remove(0);//创建根结点TreeNode root = new TreeNode(rootVal);//找根结点在中序遍历的位置int mid = inList.indexOf(rootVal);//进行切分,并建立左子树与右子树root.left = makeTree(preList,inList.subList(0,mid));root.right = makeTree(preList,inList.subList(mid + 1, inList.size()));return root;}
}


总结

提示:这里对文章进行总结:
 

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...