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

红黑树介绍

红黑树Red-Black Tree是一种自平衡的二叉查找树它是由 Rudolf Bayer 在 1972 年发明的。它在每个节点上增加一个存储位表示节点的颜色可以是红色或黑色通过对任何一条从根到叶子的路径上各个节点的颜色进行约束红黑树确保没有一条路径会比其他路径长出两倍因此是近似平衡的。红黑树的五大性质每个节点要么是红色要么是黑色。根节点是黑色。所有叶子节点NIL 节点即空节点都是黑色。通常将叶子视为虚拟的、黑色的空节点方便处理边界。如果一个节点是红色则它的两个子节点都是黑色。即不能有两个连续的红色节点。对于每个节点从该节点到其所有后代叶子节点的简单路径上均包含相同数目的黑色节点。这条性质被称为“黑色完美平衡”或“黑色高度一致”这些性质保证了红黑树的关键特性从根到叶子的最长路径不超过最短路径的两倍。因此红黑树的高度大致维持在 O(log n)从而在动态插入和删除时仍能保持较高的查找效率。为什么需要红黑树普通的二叉查找树在极端情况下如插入有序数据会退化成链表导致查找效率从 O(log n) 降至 O(n)。红黑树通过颜色和旋转操作来维持平衡避免了这种退化保证了在最坏情况下基本动态操作查找、插入、删除的时间复杂度为 O(log n)。常见应用许多编程语言的集合类或标准库中的有序关联容器如 C STL 中的map和setJava 中的TreeMap和TreeSet都基于红黑树实现。在 Linux 内核中红黑树用于管理内存区域、调度器等。一些文件系统如 Ext4也使用红黑树来组织目录项。插入与删除红黑树的插入和删除操作会破坏上述性质因此需要执行重新着色和旋转左旋或右旋来恢复平衡。这些调整通常需要 O(log n) 的时间并且最多进行 O(1) 次旋转因此整体效率很高。插入过程简略按二叉查找树规则插入新节点并将其着色为红色因为红色更容易调整且不会立即破坏性质 5。如果父节点是黑色则无需调整如果父节点是红色则违反了性质 4需要根据叔叔节点的颜色进行重新着色或旋转直到满足所有性质。删除过程简略删除节点可能破坏性质 5黑色节点数量变化因此需要引入“双重黑色”的概念并通过旋转和着色来修复。旋转操作左旋以某个节点为支点将其右子节点提升为新的父节点。右旋以某个节点为支点将其左子节点提升为新的父节点。旋转操作不改变二叉查找树的性质但能调整树的结构以恢复平衡。与 AVL 树的对比红黑树和 AVL 树都是自平衡二叉查找树。AVL 树平衡更严格左右子树高度差不超过 1因此查找更快但插入和删除的旋转次数可能更多。红黑树在插入和删除时通常需要的旋转次数更少平均因此更适用于频繁插入删除的场景。在大多数实际应用中红黑树是更常用的选择。总结来说红黑树是一种高效、可靠的平衡二叉查找树通过颜色约束和旋转操作保证了动态集合操作的对数时间复杂度广泛应用于系统底层和标准库中。红黑树可视化演示用括号表示法你也可以将红黑树想象为每个节点带有颜色标记的二叉查找树。在线演示网站如 Red/Black Tree Visualization提供了动态的图片和动画帮助你直观理解插入、删除和旋转过程。

相关文章:

红黑树介绍

红黑树(Red-Black Tree)是一种自平衡的二叉查找树,它是由 Rudolf Bayer 在 1972 年发明的。它在每个节点上增加一个存储位表示节点的颜色,可以是红色或黑色,通过对任何一条从根到叶子的路径上各个节点的颜色进行约束&a…...

【研知有术论文发表】投中真香!三区园艺学性价比SCI期刊推荐,巨好投

ISSN:0014-2336五年影响因子:1.8收录数据库:SCIE、Scopus等丨期刊简介《EUPHYTICA》是一本由Springer Netherlands出版的国际性学术期刊,创刊于1952年,在植物育种领域历史悠久,非OA期刊。目前位于农林科学大…...

Zemax转CODEV文件

点击确定,重新打开zemax打开源文件,另存为.zmx打开CODE V此处粘贴.zmx文件的地址,并且注意删除引号...

复制一个链接,1分钟提取视频全文——视频转文字我用了半年

信息焦虑这件事,天花板很高。每天刷视频、收藏课程、囤教程,感觉自己在学习。但一周后,能复述出来的内容——不超过 3 条。大多数人的卡点不是「没有好内容」。是内容进来了,但没有真正被处理过。这篇内容,想认真说一个…...

Redis(Remote Dictionary Server)的应用场景与使用方法(基于内存的高性能NoSQL数据库,支持持久化,并提供多种数据结构)RDB、AOF、主从复制、哨兵、集群

文章目录Redis 的应用场景与使用方法详解一、Redis 简介二、Redis 典型应用场景1 缓存(Cache)2 分布式会话(Session 共享)3 分布式锁4 消息队列5 排行榜系统6 限流系统7 实时统计三、Redis 基本使用方法1 安装 Redis2 基本数据操作…...

德电推出全球首个“多轨物联网漫游”:地面与太空首次“无缝切换”

2026年2月13日,德国电信(Deutsche Telekom)在巴塞罗那世界移动通信大会召开前夕宣布:该公司已成为全球首家提供多轨物联网(IoT)漫游服务的移动网络运营商。这意味着物联网设备可以在地面移动网络与卫星网络…...

【案例共创】华为云码道生成表格提取助手,百份Word表格一键提取,秒变Excel!

本案例由开发者:banjin提供,华为开发者空间案例中心优化并收录。 最新案例动态,请查阅【案例共创】华为云码道生成表格提取助手,百份Word表格一键提取,秒变Excel!。小伙伴们快来进行实操吧! 一…...

OpenClaw Token深度优化:节省50%+成本

OpenClaw作为一款强大的AI自动化工具,其Token消耗问题已成为许多用户面临的实际挑战。一个典型的OpenClaw会话可能从最初的几百Token迅速增长到几万甚至几十万,导致成本飙升和响应延迟。本文将从技术原理、配置优化和使用习惯三个维度,提供一…...

深度优先搜索(dfs)

深度优先搜索 1 什么是图的遍历 图的遍历(Graph Traversal): 指的是从图中的某一个顶点开始,按照一定规则访问图中的所有顶点,并且每个顶点只访问一次的过程。 简单理解: 就像在一个由很多点和线组成的网络…...

JAVA进阶-锁

1.悲观锁和乐观锁悲观锁:在修改数据时,一定有别的线程来使用,一定会发生并发冲突,所以在获取数据的时候会加锁。JAVA中的synchronized和lock都是悲观锁。乐观锁:在修改数据时,一定没有别的线程来使用&#…...

Cesium快速入门到精通系列教程二十三:综合

一、viewer.cesiumWidget.container.appendChild() 把你自定义的 HTML 元素(弹窗、按钮、图标等)添加到 Cesium 画布的容器里,让它显示在 3D 地球场景上。 // 1. 创建一个自定义弹窗 div const infoDiv = document.createElement(div); infoDiv.style.position = absolute…...

JAVA数据结构 DAY8-堆

本系列可作为JAVA学习系列的笔记,文中提到的一些练习的代码,小编会将代码复制下来,大家复制下来就可以练习了,方便大家学习。 点赞关注不迷路!您的点赞、关注和收藏是对小编最大的支持和鼓励! 系列文章目录…...

2026-03-17 每日作战任务:RAG 语料高效切分(Text Chunking)与处理

2026-03-17 每日作战任务:RAG 语料高效切分(Text Chunking)与处理每日学习代码关联仓库地址:https://gitee.com/lqx_learn/java-ai.git一、 业务场景 昨天我们运用 JDK 17 的 FileChannel 与 MappedByteBuffer,实现了大…...

Android Studio 安装教程(Windows 超详细图文版)

本教程将从 准备工作→ 下载 → Android Studio安装 → SDK配置 → 创建第一个项目 全流程讲解,适合 AndroidAndroid开发零基础入门。 一、Android Studio简介 Android Studio 是 Google 官方推出的 Android应用开发IDE,用于开发 Android APP。它基于 I…...

SPI子系统源码剖析--(2)Spi_Master驱动框架

1. spi_masterspi_master对应spi控制器,是对引脚的管理,同时可以通过cs引脚选择从设备发送消息2. SPI传输概述1.1 数据组织方式使用SPI传输时,最小的传输单位是"spi_transfer",对于一个设备,可以发起多个spi…...

速看!!安全员ABC证靠谱的查询方式有哪几种?分别是怎么查询呢?

很多人报考安全员都会有疑虑,担心自己考的安全员不是正规的,考出来没有用,不能在正规网站查询到,今天星禾智慧老师告诉您安全员ABC靠谱的查询方式,保证你拿到的证书不再有假🍎🧤一、湖北安全员A…...

软件综合项目-mqtt

依赖的第三方库https:CURL库SQLite:SQLite库MQTT库:Paho库MQTT属于应用层协议,支持其实现的传输协议为TCPHTTPS适用于传输的数据量比较大情况,传输方式为字符单向传输MQTT传输数量比较小,二进制传输&#x…...

2026人事系统排行榜:一体化+AI,11家企业谁是TOP选手?

2026年一体化AI人事系统TOP11深度评测:谁领跑AI原生时代?2026年,HR SaaS行业已全面迈入AI原生架构全链路一体化的竞争新阶段。企业对人系统的核心诉求,从“功能叠加AI”进化为“从底层架构融入AI”,要求AI能贯穿招聘、…...

ssm+java2026年毕设社区疫情管理系统【源码+论文】

本系统(程序源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景关于社区公共卫生应急管理问题的研究,现有研究主要以宏观层面的城市公共卫生体系构建、重大疫情应急响应机制为主&…...

【亲测好用】数据权限管理能力演示

导言: 作为一名企业管理者或业务人员,您是否曾遇到过这样的烦恼:(1)销售人员看到了不该看的财务数据?(2)合作伙伴访问了超出约定范围的信息?(3)不…...

Paperzz AI 毕业论文写作:从选题到成文,本科论文高效交付的智能解决方案

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertation 在本科毕业论文的创作路上,从确定选题到完成初稿,从文献梳理到格式规范,每…...

Paperzz AI 初稿引擎:重构本科毕业论文写作,从选题到终稿一站式高效通关

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertation 引言 本科毕业论文的创作,是大学生学业生涯的收官之战,也是对专业知识与学术能力的综…...

泰思特电子分享_EMC测试电流探头选型差异性及影响因素探讨

本文主要进行EMC测试电流探头选型差异性及影响因素探讨,围绕电流探头核心技术指标进行介绍,根据EMC测试不同标准、不同测试项目对电流探头的需求差异,分析了电流探头选型的关键影响因素以及国内外主流厂家不同型号产品的对比,为EM…...

基于能量分配的光伏混合储能系统仿真模型 ①光伏:采用mppt控制实现最大功率跟踪 ②蓄电池与超...

基于能量分配的光伏混合储能系统仿真模型 ①光伏:采用mppt控制实现最大功率跟踪 ②蓄电池与超级电容:构成混合储能系统,电池实现连续功率供应,超级电容提供瞬态功率供应 ③拓扑:光伏DC/DC采用boost变换器,混…...

APM使用LUA脚本发送实现遥控器PWM信号输出CAN协议信号

需求:由于舵机是CAN总线舵机,需实现APM开源飞控遥控器输入PWM通道到CAN的发送。 方法1:修改APM固件源码,编译,运行,测试。实现复杂。 方法2:使用lua脚本。实现简单 目前采用方法2,使…...

LangGraph 核心概念

LangGraph是LangChain 生态的 “进阶编排框架”,是 AgentExecutor升级版,基于图结构解决复杂工作流 / 多智能体问题,兼容 LangChain 所有组件。AgentExecutor 是「单智能体固定循环执行器」,适合简单线性任务;LangGrap…...

零基础搭建免费IP代理池:从原理到实战的保姆级指南

在数据驱动型业务中,很多企业都会接触到“IP代理池”这一概念。尤其是在进行公开数据整合、市场信息监测等场景时,单一IP往往难以支撑持续稳定的请求需求,这时代理池就成为重要基础设施。但对于初学者来说,“搭建代理池”听起来复…...

努力学习了一辈子,突然发现学习没什么用了

从小,我是众人眼中的 “学习标兵”。到现在,每天一节法语,一篇英语阅读,依然雷打不动:但最近几个月,随着老杨的“眨眼猫会务智能体”中对报名、签到、查座、AI会务助理的全面 “AI化改造”,老杨…...

大模型的那点事儿

大模型参数调优完全指南:从模型选择到参数配置 作者:虾兵一号 发布时间:2026-03-17 关键词:大模型参数、模型选择、Temperature、Top P、推理参数、LLM调优 一、前言 在使用大模型 API 时,两个问题最让人头疼&#xf…...

python-web自动化-selenium(1)

目录 资源 驱动器下载流程 设置、创建启动浏览器 设置浏览器Options() 创建启动浏览器webdriver.Chrome() 完整代码 打开网页,关闭标签页,关闭浏览器 打开网址get() 关闭当前标签页close() 完整代码 最大化最小化 最大化maximize_window() 最…...