当前位置: 首页 > 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)

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Javascript——宏任务微任务与JavaScript引擎的事件循环(Event Loop)和任务调度
  • C语言求平方和倒数
  • 【区块链+社会公益】第一反应互助急救链 | FISCO BCOS应用案例
  • leetcode50. Pow(x, n),快速幂算法
  • Java 代码详解:删除链表中的倒数第 N 个节点
  • JavaScript 数组迭代
  • WPF篇(5)- Border控件(边框布局)+GridSplitter分割窗口
  • Linux虚拟化技术的演进:Xen与KVM的历程与影响
  • 【Kubernetes】k8s集群之Pod容器资源限制和三种探针
  • 河南萌新联赛2024第(四)场:河南理工大学补题(B,C,I)
  • 软件测试面试题汇总,超详细整理。。。
  • 【https】无法安装OpenSSL时如何在局域网开通https服务
  • 常见8种数据结构
  • 好领导都会用三招管好下属!
  • 三数之和(LeetCode)
  • php的引用
  • [微信小程序] 使用ES6特性Class后出现编译异常
  • 【JavaScript】通过闭包创建具有私有属性的实例对象
  • egg(89)--egg之redis的发布和订阅
  • Git的一些常用操作
  • mysql_config not found
  • node入门
  • php的插入排序,通过双层for循环
  • PV统计优化设计
  • React的组件模式
  • Ruby 2.x 源代码分析:扩展 概述
  • Spring声明式事务管理之一:五大属性分析
  • ⭐ Unity 开发bug —— 打包后shader失效或者bug (我这里用Shader做两张图片的合并发现了问题)
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • Vue--数据传输
  • 不发不行!Netty集成文字图片聊天室外加TCP/IP软硬件通信
  • 动态魔术使用DBMS_SQL
  • 如何胜任知名企业的商业数据分析师?
  • 想晋级高级工程师只知道表面是不够的!Git内部原理介绍
  • 原生JS动态加载JS、CSS文件及代码脚本
  • 远离DoS攻击 Windows Server 2016发布DNS政策
  • SAP CRM里Lead通过工作流自动创建Opportunity的原理讲解 ...
  • 阿里云重庆大学大数据训练营落地分享
  • ​TypeScript都不会用,也敢说会前端?
  • # Apache SeaTunnel 究竟是什么?
  • #APPINVENTOR学习记录
  • #QT(一种朴素的计算器实现方法)
  • #vue3 实现前端下载excel文件模板功能
  • (19)夹钳(用于送货)
  • (23)Linux的软硬连接
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第2节(共同的基类)
  • (LeetCode) T14. Longest Common Prefix
  • (pojstep1.1.1)poj 1298(直叙式模拟)
  • (ZT)薛涌:谈贫说富
  • (二) Windows 下 Sublime Text 3 安装离线插件 Anaconda
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (附源码)计算机毕业设计ssm高校《大学语文》课程作业在线管理系统
  • (十八)三元表达式和列表解析
  • (四)Linux Shell编程——输入输出重定向
  • (一)基于IDEA的JAVA基础12