【LeetCode】升级打怪之路 Day 16:二叉树题型 —— 二叉树的构造

今日题目:

  • 654. 最大二叉树
  • 105. 从前序与中序遍历序列构造二叉树
  • 106. 从中序与后序遍历序列构造二叉树
  • 889. 根据前序和后序遍历构造二叉树

目录

      • LC 654. 最大二叉树 【easy】
    • Problem:根据遍历序列来还原二叉树 【classic】 ⭐⭐⭐⭐⭐
      • LC 105. 从前序与中序遍历序列构造二叉树
      • LC 106. 从中序与后序遍历序列构造二叉树
      • LC 889. 根据前序和后序遍历构造二叉树 【稍有难度】

今天主要练习了二叉树的构建的相关题目,典型的是从前序、中序、后序遍历的结果中的两个来还原一颗二叉树,这类题目的技巧类似,同时也是高频考题,需要重点掌握。

二叉树的构造问题一般都是使用「分解问题」的思路:构造整棵树 = 根节点 + 构造左子树 + 构造右子树

LC 654. 最大二叉树 【easy】

654. 最大二叉树

这个题目难度不大,但这个题经典地体现了使用递归的方法来构建一个二叉树

Problem:根据遍历序列来还原二叉树 【classic】 ⭐⭐⭐⭐⭐

这类题目给出前序、中序、后序遍历的序列中的两个,要求来还原二叉树。

要使用分解问题的思路,着眼于如何构造一个二叉节点,然后递归地构建其左右子树。整体思路大致都是

  1. 先从一个序列中确定出根节点的值,创建一个根节点
  2. 利用根节点的值,将两个序列切割成两部分,然后递归构建左右子树

具体在实现上,让我们从例题中具体学习。

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

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

这个题目给出了前序遍历和中序遍历的结果,让我们还原二叉树。

这类题目首先画出一张图,便于我们确定切割的界限:

前序和中序

画了这张图后,我们就可以知道:

  • preorder 的首元素就是 root
  • 利用 root 可以将 inorder 切分出左子树和右子树,从而得知左子树的大小 leftSize
  • 利用 leftSize,就可以将 preorder 也切分成左子树和右子树
  • 将切分后的用于递归构建

代码示例:

代码示例
这里有几个关键点:

  • build 函数是主要逻辑所在,其参数包括了两个遍历序列及其范围,便于通过界定范围来递归构建左右子树
  • 先确定 root value,构建出 root,然后切分遍历序列并递归构建(计算出左子树大小 leftSize 对于界定切分范围很有用
  • 千万别把递归构建时的范围弄错了。有个验证的小技巧:root.left 的 build 中的范围、root、root.right 的 build 的范围,这三者应该能够形成一个连续的区间。这个技巧对于检查以及防止多一个少一个这种失误很有用

LC 106. 从中序与后序遍历序列构造二叉树

106. 从中序与后序遍历序列构造二叉树

学会了上一个题目后,这个题的套路一样,所以难度就不大了。代码上也和上一题差不多:

在这里插入图片描述
可以看到。套路基本一模一样。

LC 889. 根据前序和后序遍历构造二叉树 【稍有难度】

889. 根据前序和后序遍历构造二叉树

这个题目和前面有点变化了,前面两个题目给的序列可以唯一确定出一个二叉树,但这个题给的前序和后序无法唯一确定一个二叉树,原因就在于尽管我们可以确定出 root value,但无法通过 root valule 来进一步切分出序列中的左子树部分和右子树部分。

这个题目解题的诀窍在于:我们可以假定一个可以是 left node 的元素作为左子树,并利用它来切分序列。例如下面这个示例:

示例图片
我们可以确定 3 是 root value,然后我们假定 preorder 中 root 的下一个元素 9 就是 left node,尽管它也可能是属于右子树。这种不确定也导致了给定的两个序列无法唯一确定一个二叉树。但幸运的是,我们只需要找到合法的一种可能就行,所以我们可以做出这种假设。

通过这种假设,我们就可以还原一棵二叉树了。这样,代码思路也就和前面两个题目一样了。代码如下:

105 题
可以看出,代码架构与之前的几乎一模一样。

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

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

相关文章

小程序 获取 手机号 47001 data format error hint

0.场景 后端获取小程序用户手机号 ,api文档 https://developers.weixin.qq.com/miniprogram/dev/OpenApiDoc/user-info/phone-number/getPhoneNumber.html 使用hutool工具作为http client 1. 正确的写法 正确示例 String tencentUrl StringUtils.format("https://api…

C++vector的使用方法

文章目录 一、vector的介绍1. 文档链接2. 简要介绍 二、vector的使用1.vector的定义(1)构造函数(2)拷贝构造函数(2)赋值重载 2. vector 增删查改(1)operator [](2&#x…

[HackMyVM]靶场 Quick3

kali:192.168.56.104 主机发现 arp-scan -l # arp-scan -l Interface: eth0, type: EN10MB, MAC: 00:0c:29:d2:e0:49, IPv4: 192.168.56.104 Starting arp-scan 1.10.0 with 256 hosts (https://github.com/royhills/arp-scan) 192.168.56.1 0a:00:27:00:00:05 (U…

树状数组+离散化求逆序对超详细讲解!

树状数组离散化求逆序对 用一个数组 w [ ] w[] w[]来记录遍历到当前数时,每个数出现的次数 由于只关心每个数前边有多少个数比他大,遍历到 i i i时,求大于 a [ i ] a[i] a[i]的数有多少个,就是对 [ a [ i ] , n ] [a[i], n] [a[i…

HTML—常用标签

常用标签&#xff1a; 标题标签&#xff1a;<h1></h1>......<h6></h6>段落标签&#xff1a;<p></p>换行标签&#xff1a;<br/>列表&#xff1a;无序列表<ul><li></li></ul> 有序列表<ol>&…

她们正在影响AI进程

今天是3月8日&#xff0c;祝广大女性同胞节日快乐&#xff01; 当下&#xff0c;人工智能正是全球科技圈最受关注的领域&#xff0c;甚至没有之一。 在人工智能领域诞生兴起的几十年内&#xff0c;女性科学家作为重要力量&#xff0c;一直在推动行业不断向前发展。 从基础算…

详谈数据结构数组名的含义

谈及背景 int a[3]; sizeof(arr) 12B &#xff0c;这个让我很不理解&#xff0c;后来通过一系列调查研究出了sizeof 一些性质: sizeof()是单目运算符&#xff0c;和‘’一样&#xff0c;不是库函数。sizeof()算结构体的大小 有对应的规则 算结构体大小与结构体中成员排列的顺序…

c++ primer中文版第五版作业第十八章

仓库地址 文章目录 18.118.218.318.418.518.618.718.818.918.1018.1118.1218.1318.1418.1518.16位置一using声明 位置二using声明 位置一using指示 位置二using指示 18.1718.1818.1918.2018.2118.2218.2318.2418.2518.2618.2618.2818.2918.30 18.1 此时r是一个range_error类型…

并查集(蓝桥杯 C++ 题目 代码 注解)

目录 介绍&#xff1a; 模板&#xff1a; 题目一&#xff08;合根植物&#xff09;&#xff1a; 代码&#xff1a; 题目二&#xff08;蓝桥幼儿园&#xff09;&#xff1a; 代码&#xff1a; 题目三&#xff08;小猪存钱罐&#xff09;&#xff1a; 代码&#xff1a; …

WebGL之使用着色器将颜色应用于 WebGL

在之前的展示中我们已经创建好了一个正方形&#xff0c;接下来我们要做的就是给它添加一抹色彩。添加颜色可以通过修改着色器来实现。 给顶点着色 在 WebGL 中&#xff0c;物体是由一系列顶点组成的&#xff0c;每一个顶点都有位置和颜色信息。在默认情况下&#xff0c;所有像…

异常-Exception

文章目录 异常-Exception常见的运行时异常NullPointerException&#xff08;空指针异常&#xff09;ArithmeticException&#xff08;数学运算异常&#xff09;ArrayIndexOutOfBoundsException&#xff08;数组下标越界异常&#xff09;ClassCastException&#xff08;类型转换…

Basis运维日常检查清单- Checklist

检查SYSTEM 是否正常GUI登入登入到系统检查所有应用服务器是否活动正常SM51检查所有SAP Instance服务器运行是否正常.检查工作进程进行SM50检查是否有运行时间很长Local ProcessSM66检查是否有运行时间很长Global Process检查陈旧锁定条目SM12在User ID栏输入*. 检查前期的锁列…

网络编程聊天室

客户端 #include <myhead.h> //创建结构体存储用户信息 struct User {char tape;char username[32];char msg[1024]; };int main(int argc, const char *argv[]) {//创建套接字与服务器进行通信int sfdsocket(AF_INET,SOCK_STREAM,0);if(sfd-1){perror("socket err…

鸿蒙实战开发Camera组件:【相机】

相机组件支持相机业务的开发&#xff0c;开发者可以通过已开放的接口实现相机硬件的访问、操作和新功能开发&#xff0c;最常见的操作如&#xff1a;预览、拍照和录像等。 基本概念 拍照 此功能用于拍摄采集照片。 预览 此功能用于在开启相机后&#xff0c;在缓冲区内重复采集…

django默认后台管理显示内容深化设置

1、设置models字段展示为只读模式 如某个字段在展示时不允许修改&#xff0c;可在admin.py的注册类下重写函数get_readonly_fields&#xff0c;例&#xff1a; def get_readonly_fields(self, request, objNone): return (dwdm,dwmc,"zjs","yyj"…

ARC-Challenge数据集分享

来源: AINLPer公众号&#xff08;每日干货分享&#xff01;&#xff01;&#xff09; 编辑: ShuYini 校稿: ShuYini 时间: 2024-2-28 该数据集由Allen Institute for Artificial Intelligence&#xff08;AI2&#xff09;发布&#xff0c;旨在推动高级问答的研究。该数据集包含…

#微信小程序(按键控制)

1.IDE&#xff1a;微信开发者工具 2.实验&#xff1a;微信小程序设计两个按钮&#xff0c;对onenet平台数据流&#xff08;旧版&#xff09;来进行http post上传&#xff0c;下位机再http get得到控制信息 3.记录 &#xff08;1&#xff09;bind-tap&#xff08;绑定函数&…

3D数字孪生运行不起来?该检查你的电脑配置了

运行3D数字孪生项目通常需要一定的计算资源和图形处理能力。以下是一些常见的电脑配置要求&#xff0c;可以作为参考&#xff1a;1处理器&#xff08;CPU&#xff09;&#xff1a;推荐使用多核心处理器&#xff0c;如Intel Core i7或更高级别的处理器。较高的时钟频率和较大的缓…

Linux shell 网络掩码地址转CIDR

例子&#xff1a; ./1.sh 255.255.255.0 ./1.sh 255.255.255.128 ./1.sh 255.255.0.0 源实现&#xff1a; #!/bin/bashnetmask_to_cidr() {local IFSlocal -a octetslocal i0local cidr0IFS. read -r -a octets <<< "$1"for octet in "${octets[]}…

Sora关于视频分镜的提示词技巧

视频分镜是视频制作中至关重要的一环&#xff0c;它决定了视频内容的结构、节奏和视觉效果。在Sora文生视频模型中&#xff0c;通过巧妙地运用提示词&#xff0c;你可以更加高效地进行视频分镜设计&#xff0c;提升视频的质量和观众体验。以下是10个关于视频分镜的提示词技巧&a…