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

【数据结构的——红黑树】

目录

  • 一、红黑树简介
  • 二、红黑树的特性
  • 三、2-3-4树与红黑树的等价关系
  • 四、红黑树的操作
    • 4.1、旋转操作
    • 4.2、红黑树的插入
      • 4.2.1、情形一
      • 4.2.2、情形二
      • 4.2.3、情形三
      • 4.2.4、情形四
      • 4.2.5、情形五
      • 4.2.6、情形六
      • 4.2.7、对插入进行小结
    • 4.3、红黑树的删除
      • 4.3.1、情形一
      • 4.3.2、情形二
      • 4.3.3、情形三
      • 4.3.4、情形四
  • 五、红黑树与AVL区别总结
  • 六、工具

一、红黑树简介

红黑树是一种自平衡的二叉查找树,是一种高效的查找树,可以在 O ( l o g 2 n ) O(log_{2}n) O(log2n)时间内完成查找、增加和删除等操作。

有了二叉搜索树,为什么需要平衡二叉树?

对于二叉搜索树,如果插入的数据是随机的,那么它就是接近平衡的二叉树,平衡二叉树(AVLTree)的操作效率较高,查增删的时间复杂度都是 O ( l o g 2 n ) O(log_{2}n) O(log2n)。但是当插入的数据有序时,二叉搜索树的结点就会只在根结点的一侧,就变成了一个链表,操作效率也因此变低,时间复杂度变为了 O ( n ) O(n) O(n)平衡二叉树的出现正是为了应对这种极端情况。

那么有了平衡二叉树,为什么还需要红黑树呢?

  • 红黑树是具备了某些特性的二叉搜索树,是一种接近平衡的二叉树,说其接近平衡是因为红黑树没有像AVL树中平衡因子的概念,它只是靠着满足红黑结点的5条性质来维持接近平衡的结构,并没有依靠平衡因子来维持绝对平衡
  • 每次对AVL进行插入(删除)时,几乎都需要通过旋转类保持平衡,在频繁进行插入(删除)的场景中,AVL的性能就大打折扣。而红黑树通过牺牲严格的平衡,换取插入(删除)时少量的旋转操作,整体性能优于AVL。
  • 在进行插入操作时,红黑树最多旋转两次就能回到平衡;进行删除操作时,最多进行三次旋转就能回到平衡。
  • 即使在最坏情况下,也能在 O ( l o g 2 n ) O(log_{2}n)
http://www.lryc.cn/news/418853.html

相关文章:

  • 第十二章:设置pod和容器权限-保障集群内节点和⽹络安全
  • 灵途科技再度入选2024年度“光谷瞪羚”企业名单!
  • Centos7.6配置阿里云镜像源
  • 梨子的功效与作用 梨子生吃熟吃功效竟大不同
  • 北斗三号5G遥测终端机系统在水库大坝安全监测应用
  • 代码随想录算法训练营第五十一天|99.岛屿数量 深搜 、99.岛屿数量 广搜、岛屿的最大面积
  • 【c++刷题笔记-图论】day62:Floyd 算法、A * 算法精讲
  • FPGA知识基础之--clocking wizard ip核的使用以及modelsim与vivado联合仿真
  • Java中的分布式日志与追踪
  • 案例精选 | 某省级妇幼保健院自动化安全运营中心建设成功实践
  • 数字化时代:传统行业的转型之路在何方?
  • 【STM32系统】基于STM32设计的按键PWM控制舵机窗帘柜子门禁家居等控制系统——文末资料下载
  • 【生成式人工智能-八-大型语言模型的能力评估】
  • Qt ts文件详解
  • 操作系统 IO 相关知识
  • C++_手写share_ptr
  • 【启明智显方案分享】6.86寸高清显示屏音频效果器解决方案
  • vue设置每次加载页面时展示一个双开门效果
  • 简单的docker学习 第8章 docker常用服务安装
  • 01、MySQL-DDL(数据定义语言)
  • RT-Thread 操作系统 之 线程间同步 IO设备模型
  • 力扣leetcode移动0(C++)
  • 阿里云部署open-webui实现openai代理服务
  • 你的工作环境,选对劳保鞋了吗?守护安全,从脚下开始!
  • 【Linux】编译器gcc/g++ 、程序翻译过程、动静态库
  • 通义灵码-阿里云推出的AI智能编码助手
  • 构建智能生态,视频监控/安防监控EasyCVR视频汇聚流媒体技术在智能分析领域的应用
  • LeetCode Hard|【460. LFU 缓存】
  • 积极参与全球能源科技前沿对话,海博思创推动绿色低碳发展
  • [工具]-ffmpeg-笔记