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

C++进阶 红黑树

一.红黑树的概念

红⿊树是⼀棵⼆叉搜索树,他的每个结点增加⼀个存储位来表⽰结点的颜⾊,可以是红⾊或者⿊⾊。通过对任何⼀条从根到叶⼦的路径上各个结点的颜⾊进⾏约束,红⿊树确保没有⼀条路径会⽐其他路 径⻓出2倍,因⽽是接近平衡的。

二.红黑树的规则

1. 节点非红即黑
2. 根节点必须黑
3. 红红不能相连
4. 任意路径黑节点数相同

红黑树如何确保最长路径不超过最短路径的2倍的?

由规则4可知,从根到NULL结点的每条路径都有相同数量的⿊⾊结点,所以极端场景下,最短路径 就就是全是⿊⾊结点的路径,假设最短路径⻓度为bh(blackheight)。

由规则2和规则3可知,任意⼀条路径不会有连续的红⾊结点,所以极端场景下,最⻓的路径就是⼀ ⿊⼀红间隔组成,那么最⻓路径的⻓度为2*bh。

综合红⿊树的4点规则⽽⾔,理论上的全⿊最短路径和⼀⿊⼀红的最⻓路径并不是在每棵红⿊树都 存在的。假设任意⼀条从根到NULL结点路径的⻓度为h,那么bh<=h<=2*bh。

三.红黑树的实现

左旋

和 AVL 树完全一样。

右旋

四.红黑树的插入

1. 插入⼀个值按⼆叉搜索树规则进行插入,插入后我们只需要观察是否符合红黑树的4条规则。

2. 如果是空树插,新增结点是黑色结点。如果是非空树插入,新增结点必须红色结点,因为⾮空树 插⼊,新增黑色结点就破坏了规则4,规则4是很难维护的。

3. 非空树插入后,新增结点必须红色结点,如果父亲结点是黑色的,则没有违反任何规则,插入结束 4. 非空树插入后,新增结点必须红黑、色结点,如果父亲结点是红色的,则违反规则

3。进⼀步分析,c是 红色,p为红,g必为黑,这三个颜色都固定了,关键的变化看u的情况,需要根据u分为以下几种 情况分别处理。

情况1:叔叔存在且为红

处理:p变黑
u变黑
g变红

处理完后继续把g替换为从c,继续向上调整

情况2:叔叔黑,且是直线

如果p是g的左,c是p的左,那么以g为旋转点进行右单旋,再把p变黑,g变红即可。p变成课这颗树新 的根,这样子树黑色结点的数量不变,没有连续的红色结点了,且不需要往上更新,因为p的父亲是黑色还是红色或者空都不违反规则

如果p是g的右,c是p的右,那么以g为旋转点进行左单旋,再把p变黑,g变红即可。p变成课这颗树新 的根,这样子树黑色结点的数量不变,没有连续的红色结点了,且不需要往上更新,因为p的父亲是黑色还是红色或者空都不违反规则

情况3:叔叔黑,且是折线

图1:

图2:

如果p是g的左,c是p的右,那么先以p为旋转点进行左单旋,再以g为旋转点进行右单旋,再把c变黑,g变红即可。c变成课这颗树新的根,这样⼦树黑色结点的数量不变,没有连续的红色结点了,且 不需要往上更新,因为c的父亲是黑色还是红色或者空都不违反规则

如果p是g的右,c是p的左,那么先以p为旋转点进⾏右单旋,再以g为旋转点进行左单旋,再把c变黑,g变红即可。c变成课这颗树新的根,这样⼦树黑色结点的数量不变,没有连续的红色结点了,且 不需要往上更新,因为c的父亲是黑色还是红色或者空都不违反规则

完整代码在文章最后

五.红黑树的验证

规则1:节点非红即黑

天然保证,不需要检查。

规则2:根节点必须是黑色

规则3:NIL节点为黑色

nullptr默认视为黑色,天然满足。

规则4:红节点不能有红孩子

规则5:所有路径黑节点数相同

先求出最左路径黑节点数作为标准值。

递归检查

完整验证函数:

六.插入完整代码

http://www.rkmt.cn/news/1465347.html

相关文章:

  • 从游戏地形到有限元分析:深入理解Delaunay三角剖分的‘空圆特性’到底有多实用
  • 从麒麟970到AIoT:聊聊寒武纪NPU芯片是如何一步步走进我们手机的
  • 别再只盯着GPU了!手把手带你认识AI芯片新贵:寒武纪NPU的架构与优势
  • ResNet结构图里的‘虚线’与‘实线’到底在说什么?给CV新手的避坑图解指南
  • STM32 CubeMX配置DFSDM驱动PDM麦克风避坑指南:从时钟树设置到DMA数据流不断流
  • 2026泰安金银回收避坑指南|本地正规黄金铂金白银回收门店排行及电话地址清单 - 余生黄金回收
  • 海螺ai制作的视频水印如何消除(免费去除) - 政企云文档
  • 备战蓝桥杯国赛【Day 26】
  • Windows下PyCharm安装XGBoost保姆级教程(含CP版本选择与避坑指南)
  • 【AI福利整合实战指南】:2024年企业落地智能福利系统的7大避坑法则与ROI提升路径
  • 呼和浩特市2026年最新黄金回收白银回收铂金回收门店排行榜及联系方式电话推荐 - 余生黄金回收
  • 遗传算法求解N皇后问题:Python实战与适应度函数设计
  • 从CT机到你的屏幕:一文搞懂DICOM文件在网络传输和存储中的那些‘坑’
  • ArcGIS Pro 3.2 保姆级教程:三步搞定用SHP文件精准裁剪TIF影像(附常见报错解决)
  • 别再只盯着复现了:从MinIO SSRF漏洞(CVE-2021-21287)看开源软件供应链安全
  • 从老古董到新玩具:手把手教你用8254芯片在Arduino上做个简易频率计
  • 给软件工程师的MIPS指令集入门:从R/I/J三种格式看懂CPU如何‘说话’
  • 运筹学面试高频考点:整数规划与松弛问题的关系,分支定界法步骤拆解(含真题)
  • 中国人民大学考研辅导机构如何选:全院系专业覆盖与直系定向推荐 - michalwang
  • 终极GKD订阅管理指南:告别广告困扰的完整解决方案
  • 有源电力滤波器若干关键技术解析【附仿真】
  • 别再死记硬背了!用Python模拟8253的6种工作模式,直观理解每个引脚变化
  • 8051单片机电池电压与剩余电量双参数数码管实时显示方案
  • 用Python搞定FEMTO-ST轴承数据集的预处理(附完整代码与避坑指南)
  • 从B-Scan图像到地下‘CT’:手把手教你解读探地雷达数据(附Python处理示例)
  • 量子软件栈MQSS架构设计与混合计算实践
  • 从Simulink数据字典到C代码:一条龙搞定Stateflow枚举(Enum)的创建、关联与部署
  • 告别点灯!用ESP32的GPIO做个智能小夜灯,ESP-IDF配置实战(附完整代码)
  • CTF实战:手把手教你用Python脚本破解RSA的dp泄露漏洞(附完整代码)
  • 给STM32H7装上‘眼睛’和‘大脑’:手把手教你用RT-Thread整合OpenMV与USB摄像头(附Python代码)