【数据结构】二叉树篇|『构造二叉树』刷题

在这里插入图片描述

  • 博主简介:努力学习的22级计算机科学与技术本科生一枚🌸
  • 博主主页: @是瑶瑶子啦
  • 每日一言🌼: 所谓自由,不是随心所欲,而是自我主宰。——康德

目录

  • 一、前言
  • 二、刷题
    • 1、最大二叉树
    • 2、从前序与中序遍历序列构造二叉树
    • 3、从中序与后序遍历序列构造二叉树
    • 4、 根据前序和后序遍历构造二叉树

一、前言

🍊 二叉树的构造问题一般都是使用「分解问题」的思路:构造整棵树 = 根节点 + 构造左子树 + 构造右子树
( 关键在于明确递归函数的定义,然后利用这个定义,构建二叉树的套路很简单,先找到根节点,然后找到并递归构造左右子树即可)

二、刷题

1、最大二叉树

🔗654. 最大二叉树
在这里插入图片描述

 public TreeNode constructMaximumBinaryTree(int[] nums) {if(nums==null||nums.length==0){return null;}//1、找到最大元素,构造根节点int max = nums[0];int index = 0;for (int i = 1; i < nums.length; i++){if(nums[i] > max){index = i;max = nums[i];}}TreeNode root = new TreeNode(max);//左子树和右子树数组构造int[] numsLeft = Arrays.copyOfRange(nums, 0, index);int[] numsRight = Arrays.copyOfRange(nums,index+1, nums.length);root.left = constructMaximumBinaryTree(numsLeft);root.right = constructMaximumBinaryTree(numsRight);return root;}

2、从前序与中序遍历序列构造二叉树

🔗105. 从前序与中序遍历序列构造二叉树

  • 👧🏻思路:

    • 大的框架还是分解成子问题,这里定义一个递归函数:build(递归函数的定义:给定二叉树前序遍历、中序遍历数组、前序数组起始坐标、前序数组末尾坐标、中序数组起始坐标、中序数组末尾坐标)
    • 在递归函数前序位置需要确定左子树两个数组的的四个坐标和右子树的四个坐标,核心是算出当前root在中序数组中的位置rootIndex
      在这里插入图片描述
  • 🙇🏻‍♀️代码:

    	public TreeNode buildTree(int[] preorder, int[] inorder) {//递归函数的定义:给定二叉树前序遍历、中序遍历数组、前序数组起始坐标、前序数组末尾坐标、中序数组起始坐标、中序数组末尾坐标int pStart = 0;int pEnd = preorder.length-1;int iStart = 0;int iEnd = inorder.length-1;return build(preorder,inorder, pStart, pEnd, iStart, iEnd);}public TreeNode build(int[] preorder, int[] inorder, int pStart, int pEnd, int iStart, int iEnd){if(pStart > pEnd){return null;}//1、先在前序数组中找到根节点TreeNode root = new TreeNode(preorder[pStart]);//2、在中序数组中找到根节点,划分左右数组int rootIndex = -1;int leftSize = 0;for(int  i = iStart; i <= iEnd; i++){if(inorder[i] == root.val){rootIndex = i;leftSize = i-iStart;break;}}root.left = build(preorder, inorder, pStart+1, pStart+leftSize, iStart ,rootIndex-1);root.right = build(preorder, inorder, pStart+leftSize+1, pEnd, rootIndex+1, iEnd);return root;}
    

3、从中序与后序遍历序列构造二叉树

🔗106. 从中序与后序遍历序列构造二叉树
在这里插入图片描述

  • 👧🏻思路:

    • 同上,关键在于四个坐标的确定要准确
      在这里插入图片描述
  • 🙇🏻‍♀️代码:

     public TreeNode buildTree(int[] inorder, int[] postorder) {int inStart = 0;int inEnd = inorder.length -1;int posStart = 0;int posEnd = postorder.length - 1;return build(inorder, postorder, inStart, inEnd, posStart, posEnd);}public TreeNode build(int[] inorder, int[] postorder, int inStart, int inEnd, int posStart, int posEnd){if(posStart>posEnd){return null;}TreeNode root = new TreeNode(postorder[posEnd]);//得到根节点//找到根节点在中序数组中的位置int index = 0;int leftSize = 0;for(int i = inStart; i <= inEnd; i++ ){if(inorder[i] == root.val){index = i;leftSize = i - inStart;break;}}//*******构建左子树右子树 */root.left = build(inorder, postorder, inStart, index-1, posStart,posStart+leftSize -1);root.right = build(inorder, postorder, index+1, inEnd, posStart+leftSize,posEnd-1);return root;}
    

4、 根据前序和后序遍历构造二叉树

🔗889. 根据前序和后序遍历构造二叉树
在这里插入图片描述

  • 👧🏻思路:
    • 根据我们知道,只通过前序+后序是无法唯一构造一棵二叉树的。那么当然了,这题告诉我们有多个答案只用返回一个即可

    • 前两个(前序+中序&&中序+后序)可以唯一确定是因为通过前序/后序数组可以在前序位置唯一确定根节点root,然后在中序数组中可以根据root分成左中序数组和右中序数组,所以是可以确定唯一一颗二叉树的。

    • 而前序+后序按照这个思路其实也不是不行,因为前序和后序的数组划分是这样的:

      🤔咦,根据上图,貌似前序和中序可以构造唯一二叉树呀
      🙅🏻‍♀️不对,因为这里我们默认了一个大前提:root+1是left子树的跟,也就是默认了左子树至少有一个节点。但是实际上 ,左子树可能为空!——我们只是选取了其中一种可能情况而言。

    • 🙋🏻构建思路
      1. 首先将前序/后序遍历的第一个节点作为根节点root
      2. 前序数组中,root后面相邻元素作为左子树的根节点(坐标记为preStartL = preStart+1);
      3. 根据前序数组中的左子树根节点在后序数组中找到左子树的根节点:坐标记为posEndL
      4. 从而求得左子树节点个数leftSize = posStartL - posStart + 1,将左右子树划分
      5. 划分后即可确定左右子树的四个坐标点,带入递归函数分解成子问题即可

在这里插入图片描述

  • 🙇🏻‍♀️代码:

     public TreeNode constructFromPrePost(int[] preorder, int[] postorder) {int preStart = 0;int preEnd = preorder.length -1;int posStart = 0;int posEnd = postorder.length - 1;return build(preorder, postorder, preStart, preEnd, posStart, posEnd);}public TreeNode build(int[] preorder, int[] postorder, int preStart, int preEnd, int posStart, int posEnd){if (preStart > preEnd) {return null;}//****** */!注意,这种情况必须特判!*****if (preStart == preEnd) {return new TreeNode(preorder[preStart]);}//************************************* */TreeNode root = new TreeNode(preorder[preStart]);//1、得到根节点//2、key:求leftSizeint preStartL = preStart+1;//int posEndL = -1;//2.1:找左子树根节点在后序数组中的位置for(int i = posStart; i <= posEnd; i++ ){if(postorder[i] == preorder[preStartL]){posEndL = i;break;}}int leftSize = posEndL - posStart + 1;root.left = build(preorder, postorder, preStartL, preStartL + leftSize -1, posStart, posEndL);root.right = build(preorder, postorder, preStartL + leftSize, preEnd, posEndL + 1, posEnd -1 );return root;}
    
  • 🍊注意!:在上面代码重点标出部分,需要特判的原因是:我们在思路部分已经讲过,这种方法默认左子树至少有一个节点(一棵树至少有两个节点),而preStart == preEnd并不满足这个大前提,所以需要特判!!


💐若有不懂的地方,欢迎随时在评论区or私信找瑶瑶子交流讨论🌺

在这里插入图片描述

  • Java岛冒险记【从小白到大佬之路】

  • LeetCode每日一题–进击大厂

  • Go语言核心编程

  • 算法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/37601.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎么使用手机远程控制Win10电脑?

可以使用手机远程控制电脑吗&#xff1f; “近期&#xff0c;我将出差一段时间。问题是&#xff0c;我希望能够从很远的地方浏览家里电脑上的一些东西&#xff0c;但我不会一直随身携带笨重的笔记本电脑。我可以手机远程访问Windows电脑吗&#xff1f; ” 当然&am…

SpringBoot请求响应

简单参数 1. 原始方式获取请求参数 Controller方法形参中声明httpServletRequest对象 调用对象的getParameter参数名 RestController public class RequestController {RequestMapping("/simpleParam")public String simpleParam(HttpServletRequest request){Strin…

Pytorch源码搜索与分析

PyTorch的的代码主要由C10、ATen、torch三大部分组成的。其中&#xff1a; C10 C10&#xff0c;来自于Caffe Tensor Library的缩写。这里存放的都是最基础的Tensor库的代码&#xff0c;可以运行在服务端和移动端。PyTorch目前正在将代码从ATen/core目录下迁移到C10中。C10的代…

12-数据结构-数组、矩阵、广义表

数组、矩阵、广义表 目录 数组、矩阵、广义表 一、数组 二.矩阵 三、广义表 一、数组 这一章节理解基本概念即可。数组要看清其实下标是多少&#xff0c;并且二维数组&#xff0c;存取数据&#xff0c;要先看清楚是按照行存还是按列存&#xff0c;按行则是正常一行一行的去读…

AIF360入门教学

1、AIF360简介 AI Fairness 360 工具包(AIF360)是一个开源软件工具包&#xff0c;可以帮助检测和缓解整个AI应用程序生命周期中机器学习模型中的偏见。在整个机器学习的过程中&#xff0c;偏见可能存在于初始训练数据、创建分类器的算法或分类器所做的预测中。AI Fairness 360…

人工智能在监控系统中的预测与优化:提升效率和响应能力

引言&#xff1a;人工智能的发展给监控系统带来了新的可能性&#xff0c;通过分析历史监控数据和其他相关数据&#xff0c;人工智能可以预测未来可能发生的事件&#xff0c;如交通拥堵、安全隐患等&#xff0c;并帮助优化监控系统的配置和资源分配。这种预测和优化的能力可以提…

2023年国赛数学建模思路 - 复盘:校园消费行为分析

文章目录 0 赛题思路1 赛题背景2 分析目标3 数据说明4 数据预处理5 数据分析5.1 食堂就餐行为分析5.2 学生消费行为分析 建模资料 0 赛题思路 &#xff08;赛题出来以后第一时间在CSDN分享&#xff09; https://blog.csdn.net/dc_sinor?typeblog 1 赛题背景 校园一卡通是集…

6.2.0在线编辑:GrapeCity Documents for Word (GcWord) Crack

GrapeCity Word 文档 (GcWord) 支持 Office Math 函数以及转换为 MathML GcWord 现在支持在 Word 文档中创建和编辑 Office Math 内容。GcWord 中的 OMath 支持包括完整的 API&#xff0c;可处理科学、数学和通用 Word 文档中广泛使用的数学符号、公式和方程。以下是通过 OMa…

vue自定义指令--动态参数绑定

在企业微信侧边栏应用中&#xff0c;给dialog添加了拖拽功能&#xff0c;但是因为dialog高度超过了页面高度&#xff0c;所以高度100%时拖拽有个bug--自动贴到窗口顶部而且企业侧边栏宽高都有限制&#xff0c;拖拽效果并不理想&#xff0c;所以就想缩小dialog再进行拖拽。 拖拽…

IntelliJ IDEA和Android studio怎么去掉usage和作者提示

截止到目前我已经写了 600多道算法题&#xff0c;其中部分已经整理成了pdf文档&#xff0c;目前总共有1000多页&#xff08;并且还会不断的增加&#xff09;&#xff0c;大家可以免费下载 下载链接&#xff1a;https://pan.baidu.com/s/1hjwK0ZeRxYGB8lIkbKuQgQ 提取码&#xf…

457. 环形数组是否存在循环

457. 环形数组是否存在循环 原题链接&#xff1a;完成情况&#xff1a;解题思路&#xff1a;参考代码&#xff1a;经验吸取 原题链接&#xff1a; 457. 环形数组是否存在循环 https://leetcode.cn/problems/circular-array-loop/description/ 完成情况&#xff1a; 解题思路…

使用Pandas进行数据清理的入门示例

数据清理是数据分析过程中的关键步骤&#xff0c;它涉及识别缺失值、重复行、异常值和不正确的数据类型。获得干净可靠的数据对于准确的分析和建模非常重要。 本文将介绍以下6个经常使用的数据清理操作&#xff1a; 检查缺失值、检查重复行、处理离群值、检查所有列的数据类型…

opencv进阶02-在图像上绘制多种几何图形

OpenCV 提供了方便的绘图功能&#xff0c;使用其中的绘图函数可以绘制直线、矩形、圆、椭圆等多种几何图形&#xff0c;还能在图像中的指定位置添加文字说明。 OpenCV 提供了绘制直线的函数 cv2.line()、绘制矩形的函数 cv2.rectangle()、绘制圆的函数cv2.circle()、绘制椭圆的…

【Quarkus技术系列】「云原生架构体系」在云原生时代下的Java“拯救者”是Quarkus,那云原生是什么呢?

云原生时代下的Java"拯救者" 在云原生时代&#xff0c;其实Java程序是有很大的劣势的&#xff0c;以最流行的spring boot/spring cloud微服务框架为例&#xff0c;启动一个已经优化好&#xff0c;很多bean需要lazy load的application至少需要3-4秒时间&#xff0c;内…

一站式自动化测试平台-Autotestplat

3.1 自动化平台开发方案 3.1.1 功能需求 3.1.3 开发时间计划 如果是刚入门、但有一点代码基础的测试人员&#xff0c;大概 3 个月能做出演示版(Demo)进行自动化测试&#xff0c;6 个月内胜任开展工作中项目的自动化测试。 如果是有自动化测试基础的测试人员&#xff0c;大概 …

面试热题(数组中的第K个最大元素)

给定整数数组 nums 和整数 k&#xff0c;请返回数组中第 k 个最大的元素。 请注意&#xff0c;你需要找的是数组排序后的第 k 个最大的元素&#xff0c;而不是第 k 个不同的元素。 输入: [3,2,1,5,6,4] 和 k 2 输出: 5提到数组中最大元素&#xff0c;我们往往想到就是先给数组…

判断自己网络所在的NAT类型

文章目录 各NAT类型介绍软件准备流程 各NAT类型介绍 NAT0: OpenInternet&#xff0c;没有经过NAT地址转换&#xff0c;公网IP NAT1: Full Cone NAT&#xff0c;动态家宽可以达到最优的状态&#xff0c;外网设备可以主动发信息给NAT1网络内的设备。 NAT2: Address-Restricted C…

Mybatis 源码 ④ :TypeHandler

文章目录 一、前言二、DefaultParameterHandler1. DefaultParameterHandler#setParameters1.1 UnknownTypeHandler1.2 自定义 TypeHandler 三、DefaultResultSetHandler1. hasNestedResultMaps2. handleRowValuesForNestedResultMap2.1 resolveDiscriminatedResultMap2.2 creat…

K8S系列二:实战入门

写在前面 本文是K8S系列第二篇&#xff0c;主要面向对K8S新手同学&#xff0c;阅读本文需要读者对K8S的基本概念&#xff0c;比如Pod、Deployment、Service、Namespace等基础概念有所了解。尚且不熟悉的同学推荐先阅读本系列的第一篇文章&#xff1a;《K8S系列一&#xff1a;概…

远程控制医疗行业应用解析:如何满足医院合规需求?

远程控制医疗行业应用解析&#xff1a;如何满足医院合规需求&#xff1f; 作为一个起源于IT行业的技术&#xff0c;以远程桌面为基础的远程控制技术目前在医疗领域也已经有了比较广阔的应用前景&#xff0c;尤其是在医疗数字化系统/设备的远程运维场景&#xff0c;已经有了一些…