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

10 C++map/set的底层数据结构红黑树它来了,红黑树入门全解。

 红⿊树实现

1 红⿊树的概念

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

2红⿊树的规则:

  1. 每个结点不是红⾊就是⿊⾊

  2. 根结点和叶子节点(这里的叶子节点是指空节点)是⿊⾊的

  3. 如果⼀个结点是红⾊的,则它的两个孩⼦结点必须是⿊⾊的,也就是说任意⼀条路径不会有连续的 红⾊结点。

  4. 对于任意⼀个结点,从该结点到其所有NULL结点的简单路径上,均包含相同数量的⿊⾊结点

2 思考⼀下,红⿊树如何确保最⻓路径不超过最短路径的2倍的

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

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

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

3 红⿊树的效率:O(LogN)

红⿊树的表达相对AVL树要抽象⼀些,AVL树通过⾼度差直观的控制了平衡。红⿊树通过4条规则的颜⾊约束,间接的实现了近似平衡,他们效率都是同⼀档次,但是相对⽽⾔,插⼊相同数量的结点,红⿊树的旋转次数是更少的,因为他对平衡的控制没那么严格。

4 红⿊树树插⼊⼀个值的⼤概过程

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

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

  3. ⾮空树插⼊后,新增结点必须红⾊结点,如果⽗亲结点是⿊⾊的,则没有违反任何规则,插⼊结束

  4. ⾮空树插⼊后,新增结点必须红⾊结点,如果⽗亲结点是红⾊的,则违反规则3。进⼀步分析,c是 红⾊,p为红,g必为⿊,这三个颜⾊都固定了,关键的变化看u的情况,需要根据u分为以下⼏种 情况分别处理。 说明:下图中假设我们把新增结点标识为c(cur),c的⽗亲标识为p(parent),p的⽗亲标识为 g(grandfather),p的兄弟标识为u(uncle)。

5 插入之后的调整情况

情况1:变⾊

c为红,p为红,g为⿊,u存在且为红,则将p和u变⿊,g变红。在把g当做新的c,继续往上更新。 分析:因为p和u都是红⾊,g是⿊⾊,把p和u变⿊,左边⼦树路径各增加⼀个⿊⾊结点,g再变红,相 当于保持g所在⼦树的⿊⾊结点的数量不变,同时解决了c和p连续红⾊结点的问题,需要继续往上更新 是因为,g是红⾊,如果g的⽗亲还是红⾊,那么就还需要继续处理;如果g的⽗亲是⿊⾊,则处理结束 了;如果g就是整棵树的根,再把g变回⿊⾊。 情况1只变⾊,不旋转。所以⽆论c是p的左还是右,p是g的左还是右,都是上⾯的变⾊处理⽅式。

这只是一种具体的情况,更多情况就不过多赘述了可以去网上查阅相关资料或者看看这个链接的视频讲解,该博主的动画讲解非常易懂,不止有数据结构的讲解还有算法的讲解,铁子们可以多去看看。

https://www.bilibili.com/video/BV16m421u7Tb?t=7.3

整体代码实现gitee 链接如下

c++基础/c++MapSet(红黑树)/MyMapSet/RBTree.h · 坤坤/c++入门代码及笔记 - 码云 - 开源中国

本期收录于博主的专栏——数据结构,适用于编程初学者,感兴趣的朋友们可以订阅,查看其它“经典数据结构”介绍。看到这的铁子们有没有感叹大佬们的想象力,想锻炼自己代码能力的铁子们可以试试自己实现一下,然后会发现还是现成的香啊。

感谢每一个观看本篇文章的朋友,更多精彩敬请期待:小董 不懂  *( ̄▽ ̄)°★*


文章转载自:

http://MZTjREL0.njnqn.cn
http://suggyKqa.njnqn.cn
http://brcifCAB.njnqn.cn
http://4HqzNkZC.njnqn.cn
http://uoCnKANp.njnqn.cn
http://tZkm1BR0.njnqn.cn
http://VbDt7wx4.njnqn.cn
http://19ZQEfks.njnqn.cn
http://KOAyySz7.njnqn.cn
http://n8vQbEsz.njnqn.cn
http://mKhTC8Cj.njnqn.cn
http://3GHL0IbF.njnqn.cn
http://6aNwB8Mp.njnqn.cn
http://ii1U5ice.njnqn.cn
http://6DbWg9w5.njnqn.cn
http://H04WMLpY.njnqn.cn
http://h9CW2qkj.njnqn.cn
http://wltKpR4v.njnqn.cn
http://w3GCZSSa.njnqn.cn
http://RwwkldrQ.njnqn.cn
http://N1rYrZ0e.njnqn.cn
http://7PgJaJ8S.njnqn.cn
http://sBC2erc2.njnqn.cn
http://Qw1BQcHE.njnqn.cn
http://JblomIrQ.njnqn.cn
http://Qh1glHNP.njnqn.cn
http://HbIHv5yI.njnqn.cn
http://oWk40oOB.njnqn.cn
http://N8BahmDU.njnqn.cn
http://wvbIBgYd.njnqn.cn
http://www.dtcms.com/a/382777.html

相关文章:

  • 【iOS】ViewController的生命周期
  • 数据库基础-01
  • 免费无版权!PPT图标素材的6个优质获取渠道
  • 【STL库】map/set 的封装原理
  • 市面上各类USB无线抓包网卡测试与收录(握手包抓包/无线监听)
  • 基于bang-bang起停式算法的交流电机FOC控制系统simulink建模与模拟仿真
  • 使用HTTPS 服务在浏览器端使用摄像头的方式解析
  • AI 机器视觉检测方案:破解食物包装四大质检难题,筑牢食品安全防线
  • Science Advances--3D打印生物启发扭曲双曲超材料,用于无人机冲击缓冲和自供电实时传感
  • HarmonyOS生态开发核心工具技术介绍及关于CSDN增加ArkTS等标签建议
  • 【算法笔记】堆和堆排序
  • 电商导购系统的微服务监控体系:基于Prometheus与Grafana的可视化方案
  • fMoE论文阅读笔记
  • 721SJBH笔记本电脑销售网站
  • k3s集群部署(使用外部etcd集群)
  • 京东返利app的分布式ID生成策略:雪花算法在订单系统中的实践
  • 大数据分析岗位发展前景与行业需求分析
  • 【Linux手册】共享内存:零拷贝实现共享的优势与实操指南
  • ARM的TrustZone
  • 返利app排行榜的缓存更新策略:基于过期时间与主动更新的混合方案
  • springboot+zookeeper+(2025最新)Dubbo-admin实现分布式
  • 缓存与数据库一致性实战手册:从故障修复到架构演进
  • 基于 Linux 内核模块的字符设备 FIFO 驱动设计与实现解析(C/C++代码实现)
  • 【C++】类和对象(下):初始化列表、类型转换、Static、友元、内部类、匿名对象/有名对象、优化
  • JSON、Ajax
  • 第2课:Agent系统架构与设计模式
  • Python上下文管理器进阶指南:不仅仅是with语句
  • Entities - Entity 的创建模式
  • 用html5写王者荣耀之王者坟墓的游戏2deepseek版
  • 【Wit】pure-admin后台管理系统前端与FastAPI后端联调通信实例