蓝桥备赛(18)- 红黑树和 set 与 map(上)
对于二叉搜索树 , 平衡二叉树 , 以及红黑树 , 目前只需要了解背后的原理 , 不做代码实现的要求 , 重要的就是了解各种操作的时间复杂度即可 , 为set 与 map 做铺垫
一、二叉搜索树
1.1 基本概念



构造一棵二叉搜索树的目的 , 并不是为了排序,而是为了提高查找和输入删除关键字的速度。
1.2 查找操作
二叉搜索树的查找是从根结点开始 ,沿某个分支逐层向下比较的过程,若二叉搜索树非空,先将给定值与根结点的关键字比较,若相等,则查找成功;若不等,如果小于根结点的关键字,则在根结点的左子树上查找,否则在根结点的右子树上查找。二这也是⼀个递归的过程。根据BST的特性(左 < 根 < 右 )从根结点开始一路向下找最坏情况下会从根节点开始,查找到叶子结点。因此时间复杂度是和树的高度有关的,而树高最差会 变成一条单链表,因此时间复杂度为 O(N)

1.3 插入操作
根据BST的特性(左 < 根 < 右 )从根结点开始一路向下找,找到合适的位置,就直接插入插入与查找的过程一致,因此时间复杂度为 O(N)

1.4 构造 BST 树
二叉搜索树的构建就是不断向原来的树中插入新的结点即可。


在极端条件下 , 时间复杂度为 O(N) ---> oh my god ! 骤增了!!!
在上面两个构造二叉排序树的过程中 , 虽然结点的值都相同 , 不同的构造顺序会有不同的二叉搜索树 , 会影响查找和插入的效率 。 并且 , 构造序列越有序 , 二叉搜索树的查找效率就越低 。
1.5 删除操作

对于第三个删除结点的情况 , 我们一般是把它变成情况一或二
1)若被删除结点是叶子结点,则直接删除
----> 此时依旧会保持二叉搜索树的性质

2)若被删除结点只有左子树或者右子树,让左子树或者右子树替代
----> 此时依旧会保持二叉搜索树的性质

3)若被删除结点有左子树和右子树



删除10这个结点:

注意:我们创建二叉搜索树其实并不是为了排序 , 而是为了快速插入、删除 以及查找元素。因为BST不是那么极端的话 , 树高维持在 logN 的范围 , 上述的各种操作其实是很快的 。 但是二叉搜索树的特性并不杜绝极端情况的出现 !!!
二、平衡二叉树
在介绍二叉搜索树的时候 , 在某些特定的情况下 , 二叉搜索树是会退化成单链表 , 并且各种操作的效率也会明显下降 。因此我们需要一些特别的手段保证这个二叉搜素树的“平衡”,进而保证各种操作的效率 。
2.1 基本概念
平衡二叉树 , 也称AVL树 , 它是具有以下性质的二叉搜索树:
1 ) 左右子树的高度差的绝对值不超过1
2 ) 左右子树分别也是平衡二叉树
如下图所示 , 结点上方的数字表示平衡因子 。 左图是一棵平衡二叉树,右图不是!

2.2 查找操作
平衡二叉树的查找 、 插入 以及 删除操 作基本上与二叉搜索树一致 , 但是需要处理操作之后的“失衡” 。
重点需要掌握两种处理失衡的操作:
1) 左旋
2) 右旋
由于平衡二叉树会限制树的高度不会过高 ,趋近于 log n 级别 , 因此时间复杂度为 O(logN)

左旋(结点1)的时候遇到(结点2) “挡着了” ,
1 ) 结点1 成为右孩子的左子树
2 ) 右孩子原本的左子树(结点2)成为该结点(结点1)的右子树

右旋(结点1)的时候遇到(结点2) “挡着了” ,
1 ) 结点1 成为左孩子的右子树
2 ) 左孩子原本的右子树(结点2)成为该结点(结点1)的左子树
2.3 插入操作
最小不平衡子树:在⼆叉搜索树中插入新结点之后,插入路径的点中,可能存在很多平衡因子的绝对值大于 1 的,此时找到 距离插入结点最近的不平衡的点 ,以这个点为根的 子树 就是 最小不平衡子树 。



2.3.1 LL型 - 右单旋
LL 表示: 新结点由于插入在 T 结点的左孩子(L)的左子树(LL)中 ,从而导致失衡。如下图所示:

T失衡了: ---> 让失衡点右旋

案例:

2.3.2 RR型 - 左单旋
RR 表示:新结点由于插入在 T 结点的右孩子(R)的右子树(RR)中,从而导致失衡。如下图所示:

T失衡了---> 让失衡点左旋

案例:

2.3.3 LR型 - 左右双旋
LR 表示:新结点由于插入在 T 结点的左孩子(L)的右子树(LR)中,从而导致失衡。如下图所示:

T失衡了: -->
1) 失衡点左孩子左旋
2) 失衡点右旋

案例:

2.3.4 RL型 - 右左双旋
RL 表示:新结点由于插入在 T 结点的右孩子(R)的左子树(RL)中,从而导致失衡。如下图所示:

T失衡了: -->
1) 失衡点的右孩子右旋
2) 失衡点左旋

案例:

2.4 构造ALV树
平衡二叉树的构造 , 就是不断向数中插入新的结点:







2.5 删除操作
与插入操作的思想类似,都是先按照二叉搜索树的形式操作,然后想办法使其平衡。具体步骤:删除结点的时候 , 调整可能不止一次 , 因为插入的时候,我们是从根结点开始查找合适的插入位置 , 是符合BST的特性 , 但是删除操作的时候 , 是随机的 。

例一:删除 30

例二:删除 10

第⼀次调整:从 10 向上找,第⼀个不平衡子树是以 49 为根的子树,高度最高的儿子是 59,高度最高的孙子是 69,呈现右孩子右孩子,因此仅需对 59 左旋⼀次。

没有第二次调整了,因为所有都已经平衡了
例三:删除 57



调整结束,因为已经到了根结点,并且根节点是平衡的。
相关文章:
蓝桥备赛(18)- 红黑树和 set 与 map(上)
对于二叉搜索树 , 平衡二叉树 , 以及红黑树 , 目前只需要了解背后的原理 , 不做代码实现的要求 , 重要的就是了解各种操作的时间复杂度即可 , 为set 与 map 做铺垫 一、二叉搜索树 1.1 基本概念 相较与于堆…...
Spring Boot集成EasyExcel
1. 初始化Spring Boot项目 首先,使用Spring Initializr(https://start.spring.io/)生成一个基本的Spring Boot项目。选择以下依赖项: Spring WebLombok (用于减少样板代码)SLF4J (用于日志记录) 2. 添加依赖 在你的pom.xml文件…...
obeaver 连接oracle 库 模式乱码
下载orai18n-12.1.0.2.0.jar 库--添加文件--把提前下载好的jar 随便放在一个文件夹下--添加文件选中,然后点击找到类, 选择类,确定即可正常 下载地址:https://download.csdn.net/download/weixin_42845364/88368302...
ChatGPT 使用教程:深度探索AI常用功能技巧
文章目录 前言一、ChatGPT介绍1.1 人工智能与自然语言处理的发展1.2 ChatGPT 的诞生与意义 二、ChatGPT 基础入门2.1 注册与登录2.2 对话界面介绍2.3 基本提问方式 三、常用功能详解3.1 文本生成3.2 问题回答3.3 语言翻译3.4 代码生成与调试 四、高级使用技巧4.1 指令优化4.2 多…...
無人機的應用程序有那些可以部署在linux server 系統
Dronecode Project:由 Linux Foundation 主導的開源項目,提供無人機航空操作系統和導航工具的開發框架,適合開發者使用。 DeepSeek-R1:這是一個人工智能模型,適用於無人機的數據處理和分析,支持在 Linux 系…...
[HUBUCTF 2022 新生赛]messy_traffic
下载附件 看到文件类型直接用wireshark打开,对MySQL协议进行追踪流,并没有什么发现,后面对NO.437发现有用信息,http追踪流 发现**system(‘cat passwd.txt’);**这里是在打开查看passwd.txt,密码是"SignUpForHUBU…...
铁人三项(第五赛区)_2018_rop题解
先启动靶机连接看看。 直接ls,就给我输出句话,看来不能直接拿flag。 那走下流程。 查下位数和其他信息: 可以看到是32位的包,开了NX,但没开其他保护。 用ida32打开looklook。 主函数就是个这,看到了弹出的…...
package.json 依赖包约束及快速删除node_modules
文章目录 一、package.json版本约束1、初始项目安装2. 已有 yarn.lock 文件的项目安装3. 特殊情况手动修改 package.json 版本:使用 yarn upgrade 命令: 二、快速删除node_modules三、depcheck 检测npm未使用的依赖 一、package.json版本约束 1、初始项…...
Compose 实践与探索六 —— 动画的流程控制与 Transition
1、Block 参数:监听每一帧 animateTo() 与 animateDecay() 中都有一个函数类型的 block 参数: suspend fun animateDecay(initialVelocity: T,animationSpec: DecayAnimationSpec<T>,block: (Animatable<T, V>.() -> Unit)? null): An…...
虚拟机Contos7为啥不能被本机电脑访问?
1.查看防火墙是否开启 systemctl status firewalld.service 2.如果防火墙关闭就可以直接被访问 3.如果防火墙打开了我们需要开放端口(下面为防火墙一系列指令) # 关闭防火墙 systemctl stop firewalld.service# 打开防火墙 systemctl start firewalld.service# 关闭开启自启…...
【21】单片机编程核心技巧:if语句逻辑与真假判断
【21】单片机编程核心技巧:if语句逻辑与真假判断 七律 条件分野 if语句判真假,括号条件定乾坤。 非零为真零为假,大括号内藏玄门。 省略虽简风险在,代码规范护本根。 单片逻辑由心控,条件分支自成文。 注释…...
Java 实现 Android ViewPager2 顶部导航:动态配置与高效加载指南
Java 实现:明确使用的编程语言。Android ViewPager2:技术栈和核心组件。顶部导航:功能点。动态配置与高效加载指南:突出动态配置的灵活性和性能优化的重点。 在 Android 中使用 Java 实现 ViewPager2 和 TabLayout 的顶部导航也是…...
Python :数据模型
一. 什么是数据模型? Python数据模型是Python对象系统的抽象,通过一组特殊方法(如__init__、__len__等)和协议(如迭代协议、上下文管理协议),定义了对象如何与语言的内置功能(如…...
idea超级AI插件,让 AI 为 Java 工程师
引言 用户可在界面中直接通过输入自然语言的形式描述接口的需求,系统通过输入的需求自动分析关键的功能点有哪些,并对不确定方案的需求提供多种选择,以及对需求上下文进行补充,用户修改确定需求后,系统会根据需求设…...
施磊老师c++笔记(五)
继承与多态-深入掌握oop语言最强大的机制 文章目录 继承与多态-深入掌握oop语言最强大的机制1.继承的基本意义2.派生类的构造过程3.重载,隐藏,覆盖4.虚函数, 静态绑定和动态绑定--面试重点5.虚析构函数--重点在于什么呢时候用6.再讨论虚函数和动态绑定7.理解多态到底是什么8.理…...
µCOS-III从入门到精通 第十四章(软件定时器)
参考教程:【正点原子】手把手教你学UCOS-III实时操作系统_哔哩哔哩_bilibili 一、软件定时器简介 1、定时器的概念与种类 (1)定时器的概念:从指定的时刻开始,经过一个指定时间,然后触发一个超时事件&…...
MySQL数据库复杂的增删改查操作
在前面的文章中,我们主要学习了数据库的基础知识以及基本的增删改查的操作。接下去将以一个比较实际的公司数据库为例子,进行讲解一些较为复杂且现时需求的例子。 基础知识: 一文清晰梳理Mysql 数据库基础知识_字段变动如何梳理清楚-CSDN博…...
KCD 北京站丨Volcano 邀您畅聊云原生智能调度技术与应用
AI与云原生技术正以前所未有的速度改变着我们的世界,而云原生技术则如同一座坚实的桥梁,连接着传统IT与现代化的数字世界。当AI与云原生相遇,它们相互赋能,相互促进,为开发者们打开了一个全新的技术宇宙。 3 月 15 日&…...
BLEU评估指标
一、介绍 用于评估模型生成的句子和实际句子差异的指标,取值在[0,1],匹配度高就距离1近,反之距离0近。这个指标计算代价小,容易理解,与语言无关,与人类评价结果高度相关。 BLEU主要基于n-gram匹配&#x…...
高效自动化测试:打造Python+Requests+Pytest+Allure+YAML的接口测试框架
一、背景 在快节奏的开发周期中,如何确保接口质量?自动化测试是关键。通过构建标准化、可复用的测试框架,能显著提升测试效率与准确性,为项目质量保驾护航[1][7]。 二、目标 ✅ 核心目标: ● 实现快速、高效的接口测试…...
如何修复 Tauri 发布后程序运行时显示 `asset not found: index.html` 的问题
如何修复 Tauri 发布后程序运行时显示 asset not found: index.html 的问题 在使用 Tauri 发布应用程序时,如果运行时出现 asset not found: index.html 的错误,通常是因为 Tauri 无法找到或正确加载前端资源文件(如 index.html)…...
BSides Vancouver: 2018 (Workshop)
BSides Vancouver: 2018 (Workshop) 来自 <https://www.vulnhub.com/entry/bsides-vancouver-2018-workshop,231/> 1,将两台虚拟机网络连接都改为NAT模式 2,攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 那么攻击机IP为192.168.23…...
rStar论文精读
论文简介 论文标题:《Mutual reasoning makes smaller LLMs stronger problem-solvers》 论文地址:https://arxiv.org/abs/2408.06195 录用会议:ICLR2025 背景与挑战 挑战1:在SLM中平衡exploration与exploitation。一些方法有很…...
【动态规划】对局匹配 (分组线性DP)
题目详情 问题描述: 小明喜欢在一个围棋网站上找别人在线对弈。这个网站上所有注册用户都有一个积分,代表他的围棋水平。 小明发现网站的自动对局系统在匹配对手时,只会将积分差恰好是K的两名用户匹配在一起。如果两人分差小于或大于K…...
python 提取视频中的音频
在Python中提取视频中的音频,你可以使用moviepy库,这是一个非常强大且易于使用的库,专门用于视频编辑。以下是如何使用moviepy来提取视频中的音频的步骤: 安装moviepy 首先,你需要安装moviepy。你可以通过pip安装它&a…...
self.cls_token在 Vision Transformer (ViT) 模型中的训练阶段和推理阶段的行为和作用的异同
self.cls_token 在 Vision Transformer (ViT) 模型中,在训练阶段和推理阶段的行为和作用是不同的,而且它的值在训练过程中会发生变化。 1. self.cls_token 的作用 在 ViT 中,self.cls_token 是一个特殊的、可学习的嵌入向量(emb…...
【量化科普】Leverage,杠杆
【量化科普】Leverage,杠杆 🚀量化软件开通 🚀量化实战教程 在量化投资领域,杠杆(Leverage)是一个核心概念,它允许投资者通过借入资金来增加投资规模,从而放大投资收益或亏损。简…...
247g 的工业级电调,如何让无人机飞得更 “聪明“?——STONE 200A-M 深度测评
一、轻量化设计背后的技术取舍 当拿到 STONE 200A-M 时,247g 的重量让人意外 —— 这个接近传统 200A 电调 70% 的重量,源自 1205624.5mm 的紧凑结构(0.1mm 公差控制)。实测装机显示,相比同规格产品,其体积…...
Maven Deploy Plugin如何使用?
在Java开发中,Maven是一个非常重要的构建工具。它不仅可以管理项目的依赖关系,还能帮助我们打包和发布项目。在Maven中,deploy插件是一个很实用的功能,它可以将构建好的项目发布到远程仓库。今天,就来聊聊如何使用Mave…...
Node.js:快速启动你的第一个Web服务器
Node.js 全面入门指南 文章目录 Node.js 全面入门指南一 安装Node.js1. Windows2. MacOS/Linux 二 配置开发环境1. VSCode集成 三 第一个Node.js程序1. 创建你的第一个Node.js程序 四 使用Express框架1. 快速搭建服务器 一 安装Node.js 1. Windows 以下是Windows环境下Node.j…...


