当前位置: 首页 > 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.jsqmd.com/news/953730/

相关文章:

  • FastAPI+React+Docker构建可上线ML Web App实战指南
  • 炉石传说终极优化插件:55项实用功能全面解锁游戏体验
  • 泰安市2026年最新黄金回收白银回收铂金回收门店排行榜及联系方式电话推荐 - 余生黄金回收
  • 智能家居DIY实战:用STM32和MQ-2打造本地烟雾报警器,无需云端也能用
  • STC89C5x单片机超声波测距实战工程:带温度校准和LCD1602实时显示
  • 呼和浩特2026靠谱金银铂回收商家盘点|全区域上门回收电话与实体门店地址汇总 - 余生黄金回收
  • 唐山市2026年最新黄金回收白银回收铂金回收门店排行榜及联系方式电话推荐 - 余生黄金回收
  • 从游戏地形到有限元分析:深入理解Delaunay三角剖分的‘空圆特性’到底有多实用
  • 机器学习Web应用构建与部署实战指南
  • 从麒麟970到AIoT:聊聊寒武纪NPU芯片是如何一步步走进我们手机的
  • ISE 14.7下GTX接口调试:手把手教你用ILA抓波形,VIO改参数(附ICON核配置避坑)
  • 告别手动计数!用ImageJ的‘二值化+形态学操作’批量处理细胞图片
  • 泰安2026靠谱金银回收商家名录|黄金铂金白银回收门店排行与联系号码汇总 - 余生黄金回收
  • 保姆级教程:用ROS+OpenCV让Bebop2无人机自动跟随一个蓝色物体(附完整代码)
  • 徐州市2026年最新黄金回收白银回收铂金回收门店排行榜及联系方式电话推荐) - 余生黄金回收
  • 2026年呼和浩特黄金白银铂金回收优质店铺排行|实体门店地址+上门回收联系方式汇总 - 余生黄金回收
  • 从照片到三维模型:用ContextCapture Center 4.4.12 快速上手实景建模
  • 别再只盯着GPU了!手把手带你认识AI芯片新贵:寒武纪NPU的架构与优势
  • MATLAB实现MacCormack格式求解喷管一维流场及动态可视化
  • ResNet结构图里的‘虚线’与‘实线’到底在说什么?给CV新手的避坑图解指南
  • STM32 CubeMX配置DFSDM驱动PDM麦克风避坑指南:从时钟树设置到DMA数据流不断流
  • 2026泰安金银回收避坑指南|本地正规黄金铂金白银回收门店排行及电话地址清单 - 余生黄金回收
  • 海螺ai制作的视频水印如何消除(免费去除) - 政企云文档
  • 备战蓝桥杯国赛【Day 26】
  • 用纯NumPy手写梯度下降:从解方程到训练神经网络
  • 2026徐州贵金属回收靠谱门店盘点|黄金铂金白银变现商家名录及电话) - 余生黄金回收
  • 别再只盯着IMSI了!USIM卡里这5个关键文件,搞懂了你才算入门移动通信
  • Java Swing写的图书馆桌面管理程序(含源码+论文,Eclipse/IDEA可直接运行)
  • 多维聚合与数据操作:构建可下钻的分析立方体
  • Windows下PyCharm安装XGBoost保姆级教程(含CP版本选择与避坑指南)