当前位置: 首页 > news >正文

JAVA练习69- 从前序与中序遍历序列构造二叉树

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


前言

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

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<Integer> preList = new ArrayList<>();List<Integer> 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<Integer> preList,List<Integer> 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;}
}


总结

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

http://www.lryc.cn/news/30906.html

相关文章:

  • brew安装问题
  • 【数据挖掘与商务智能决策】第一章 数据分析与三重工具
  • 计算机底层:BDC码
  • 【C++】平衡二叉搜索(AVL)树的模拟实现
  • [2019红帽杯]childRE
  • 2D图像处理:九点标定_下(机械手轴线与法兰轴线不重合)(附源码)
  • 【二分查找】分巧克力、机器人跳跃、数的范围
  • Hyperf使用RabbitMQ消息队列
  • 【Linux】P3 用户与用户组
  • Spring核心模块——Aware接口
  • Linux网络编程 第六天
  • STM32开发(六)STM32F103 通信 —— RS485 Modbus通信编程详解
  • AcWing1049.大盗阿福题解
  • python日志模块,loggin模块
  • 接口自动化入门-TestNg
  • Spring AOP —— 详解、实现原理、简单demo
  • (蓝桥真题)异或数列(博弈)
  • 4万字数字政府建设总体规划方案WORD
  • CCF/CSP 201709-2公共钥匙盒100分
  • 【OC】Blocks模式
  • 软件设计师教程(七)计算机系统知识-操作系统知识
  • 蓝桥杯2023/3/2
  • 【IoT】创业成功不可或缺的两个因素:能力和趋势
  • 2020蓝桥杯真题日期格式 C语言/C++
  • 总时差与自由时差
  • LeetCode两个数组的交集-跳跃游戏- 最长有效括号
  • mysql普通索引与唯一索引怎么选择
  • JavaWeb开发(三)3.5——Java的反射机制
  • Python每日一练(20230305)
  • SpringBoot三种方法实现定时发送邮件的案例