集合系列(二十五) -二叉树、平衡二叉树、红黑树性能总结

一、摘要

二叉树,作为一种数据结构,在实际开发中,有着非常广泛的应用,尤其是以平衡二叉树、红黑树为代表,在前几篇文章中,我们详细的介绍了BST、AVL、RBT的算法以及代码实践,下面简要概括描述一下这三种树,以及它们之间的优劣。

二、BST

二叉查找树(英文全称:Binary Search Tree,简称:BST)是计算机科学中最早投入实际使用的一种树形结构,特性定义比较粗放(一个节点,最多2个分支),因此在树形形态结构上,有着多样,例如下图:

很明显,不同的形状,所需查找的次数是不一样的!

BST 的操作过程:

  • 查找操作:任何一个数据的查找过程都需要从根结点出发,沿某一个路径朝叶子结点前进,因此查找中数据比较次数与树的形态密切相关。

当树中每个结点左、右子树高度大致相同时,树高为logN,则平均查找长度与logN成正比,查找的平均时间复杂度在O(logN)数量级上。

当树形结构为一个单子树时,此时树高n,则平均查找长度为(n+1)/2,查找的平均时间复杂度在O(N)数量级上。

  • 插入操作:先通过查找方法找到合适的位置,然后将新结点插入到树的叶子上,完全不需要改变树中原有结点的组织结构。

插入一个节点的时间与查找一个插入合适的位置的时间完全相同。

  • 删除代价:当删除一个节点A,首先需要定位到这个节点A,这个过程需要一个查找的时间。然后根据树的形态分析,如果被删除结点的左、右子树只有一个存在,则改变形态的代价仅为O(1)。如果被删除结点的左、右子树均存在,只需要将A节点的左孩子的最末端的右子树或者A节点的右孩子的最末端的左子树结点与A互换,最后删除该节点即可。

删除操作的时间复杂度最大不会超过O(logN)。

BST效率总结:

  • 查找最好时间复杂度O(logN),最坏时间复杂度O(N)。
  • 插入、删除操作算法简单,时间复杂度与查找差不多。

三、AVL

二叉查找树在最差情况下和顺序查找效率相当,这点是无法忍受的。

平衡二叉查找树的出现,主要是为了解决当二叉树查找树形态结构变成一个链条结构的时候,查找效率变低的问题,算法由Adel'son-Vel'skiiLandis两位大神发明,同时也俗称AVL树,特性如下:

  • 它的左子树和右子树都是平衡二叉树;
  • 且它的左子树和右子树的深度之差的绝对值(平衡因子 ) 不超过1;

简单的说,就是为了保证平衡,当前节点的左子树、右子树的高度差不超过1!

当树的左、右子树高度超过差超过1时,核心就是通过左旋转、右旋转实现树再次高度平衡。

AVL 的操作过程:

  • 查找操作:AVL是严格平衡的BST(平衡因子不超过1)。查找过程与BST一样,只是AVL不会出现最差情况的BST(单支树)。因此查找效率最好,最坏情况都是O(logN)数量级的。

  • 插入操作:AVL插入与BST思路一样,不同的是AVL必须要保证严格平衡(height<=1),每一次插入数据使得AVL中某些结点的平衡因子超过1就必须进行旋转操作。事实上,AVL的每一次插入结点操作最多只需要旋转1次(单旋转或双旋转)。因此,总体上插入操作的代价仍然在O(logN)级别上(插入结点需要首先查找插入的位置)。

  • 删除操作:AVL删除结点的算法与BST思路一样,但是删除之后必须检查从删除结点开始到根结点路径上的所有结点的平衡因子。因此删除的代价稍微要大一些。每一次删除操作最多需要O(logN)次旋转。因此,删除操作的时间复杂度为O(logN)+O(logN)=O(2logN)。

AVL 效率总结:

  • 查找的时间复杂度维持在O(logN),不会出现最差情况。
  • AVL树在执行每个插入操作时最多需要1次旋转(单旋转或双旋转),其时间复杂度在O(logN)左右。
  • AVL树在执行删除时代价稍大,执行每个删除操作的时间复杂度需要O(2logN)。

四、RBT

平衡二叉查找树通过严格平衡策略以牺牲建立查找结构的代价,换来了稳定的查找时间复杂度。但是相对来说,在删除方面,时间复杂度稍大。

于是就出现了平衡二叉B树,后来,在1978年被 Leo J. Guibas 和 Robert Sedgewick 修改为如今的红黑树。

红黑树(英文全称:red-black-tree,简称:RBT),特性如下:

  • 1.每个节点要么是黑色要么是红色;
  • 2.根节点是黑色;
  • 3.每个叶子节点是黑色;(注意:这里叶子节点,是指为空的叶子节点)
  • 4.如果一个节点是红色的,则它的子节点必须是黑色的;(说明父子节点之间不能出现两个连续的红节点)
  • 5.从一个节点到该节点的子孙节点的所有路径上包含相同数目的黑节点;

特性5确保没有一条路径会比其他路径长出俩倍,因而,红黑树是相对的接近平衡的二叉树,但是相比平衡二叉树而言,尤其是删除的时间复杂度,有所降低。

RBT 的操作过程:

  • 查找操作:由于红黑树的性质(最长路径长度不超过最短路径长度的2倍),可以说明红黑树虽然不像AVL一样是严格平衡的,但平衡性能还是要比BST要好。其查找代价基本维持在O(logN)左右,但在最差情况下(最长路径是最短路径的2倍少1),比AVL要略逊色一点。

  • 插入操作:RBT插入结点时,需要旋转操作和变色操作。但由于只需要保证RBT基本平衡就可以了。因此插入结点最多只需要2次旋转,这一点和AVL的插入操作一样。虽然变色操作需要O(logN),但是变色操作十分简单,代价很小。

  • 删除代价:RBT的删除操作代价要比AVL要好的多,删除一个结点最多只需要3次旋转操作。

RBT 效率总结:

  • 查找效率最好情况下时间复杂度为O(logN),但在最坏情况下比AVL要差一些,但也远远好于BST。
  • 插入和删除操作改变树的平衡性的概率要远远小于AVL(RBT不是高度平衡的)。因此需要的旋转操作的可能性要小,而且一旦需要旋转,插入一个结点最多只需要旋转2次,删除最多只需要旋转3次(小于AVL的删除操作所需要的旋转次数)。虽然变色操作的时间复杂度在O(logN),但是实际上,这种操作由于简单所需要的代价很小。

五、总结

平衡二叉查找树、红黑树,在查询、插入、删除操作方面都是基于二叉查找树的算法思路,不同点是:插入、删除之后的调整过程,平衡二叉查找树主要是通过左旋转、右旋转实现树高度再次平衡,而红黑树因为引进了颜色,相比平衡二叉查找树,多了一个颜色转换操作。

三者整体比较,红黑树要优于平衡二叉查找树,远优于二叉查找树!

六、写到最后

最近无意间获得一份阿里大佬写的技术笔记,内容涵盖 Spring、Spring Boot/Cloud、Dubbo、JVM、集合、多线程、JPA、MyBatis、MySQL 等技术知识。需要的小伙伴可以点击如下链接获取,资源地址:技术资料笔记。

不会有人刷到这里还想白嫖吧?点赞对我真的非常重要!在线求赞。加个关注我会非常感激!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/695790.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

object.key()用法

object.key(obj) 一、概念&#xff1a;返回一个由一个给定对象的自身可枚举属性组成的数组。 二、用法&#xff1a; 1、参数为对象&#xff1a;则返回为 对象属性名组成的数组。 let obj {日期&#xff1a;date,姓名&#xff1a;userName,地址:address}console.log(Object.k…

栈结构(详解)

1.栈的概念 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的数据元素遵守后进先出LIFO&#xff08;Last In First Out&#xff09;的原则。 压栈&am…

计算机网络复习-应用层

概述 传输层以及以下的层提供完整的通信服务&#xff0c;不需要管传输&#xff0c;只需要往上对接用户即可。应用层是面向用户的一层 定义应用间通信的规则 应用进程的报文类型 (请求报文、应答报文)报文的语法、格式应用进程发送数据的时机、规则 DNS详解 DNS&#xff1a…

分布式与一致性协议之PBFT算法(二)

PBFT算法 如何替换作恶的主节点 虽然PBFT算法可以防止备份节点作恶&#xff0c;因为这个算法是由主节点和备份节点组成的&#xff0c;但是&#xff0c;如果主节点作恶(比如主机点接收到了客户端的请求&#xff0c;但就是默不作声&#xff0c;不执行三阶段协议)&#xff0c;那…

STM32使用ESP01S连接阿里云物联网平台

一、ESP01S烧录MQTT固件准备 首先准备好烧录工具&#xff0c;可以从官网上进行下载。 MQTT固件官网网址&#xff1a;AT固件汇总 | 安信可科技 (ai-thinker.com) 进去后如下图界面&#xff0c;向下翻找找到MQTT固件&#xff08;1471&#xff09;下载固件即可。 烧录工具光网地…

沃比得 DP16A 对数周期天线 100MHz~6GHz

沃比得DP16A对数周期天线该天线可用做超短波发射或接收天线&#xff0c;工作频率为 100MHz&#xff5e;6GHz。具 有频带宽&#xff0c;性能可靠&#xff0c;增益高等优点&#xff0c;是理想的无线电频谱管理、EMC 测试、电子对抗等领域 的定向接收、发射天线。 应用领域 ●…

【spring】application.yml导入额外配置文件

有时候application.yml 已经配置很多配置已经很大很乱了想把他们拆出去放在一个独立的XX.yml文件管理。这时候就用到了 spring.config.import 属性。 spring.config.import spring.config.import 是 Spring Boot 2.4 版本引入的一个配置属性&#xff0c;用于导入额外的配置数…

IT小能手秘籍:看工单与任务单如何携手玩转服务管理

在ITSM这摊事儿里&#xff0c;我们有两种手段来管理IT小哥们忙活的那些维护工作&#xff0c;一种叫工单&#xff08;Ticket&#xff09;&#xff0c;另一种则是任务单&#xff08;Task&#xff09;。这哥俩到底有啥不同&#xff0c;又怎么互相帮衬着呢&#xff1f; 工单嘛&…

react18【系列实用教程】moxb —— 集中状态管理 (2024最新版)

官方文档 https://www.mobxjs.com/ moxb 和 redux 都能用于 react 的状态管理&#xff0c;但 moxb 更简单&#xff0c;适合规模不大的应用 &#xff08;规模大的应用若合理组织代码结构&#xff0c;也能用 moxb&#xff09; 安装 moxb npm i mobx npm i mobx-react-lite此处安…

支付宝支付开票

完成 接入准备 后&#xff0c;商家/服务商可根据本文内容快速接入 支付开票。 1 简介 消费者使用支付宝完成支付后&#xff0c;可在该笔交易的对应的页面直接发起开票请求&#xff0c;用户之后进入开票页面选择抬头&#xff0c;申请开具发票。商家开票平台开具发票&#xff0…

OpenCV与AI深度学习 | 基于机器视觉的磁瓦表面缺陷检测方案

本文来源公众号“OpenCV与AI深度学习”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;基于机器视觉的磁瓦表面缺陷检测方案 永磁铁氧体磁瓦广泛应用于汽车、家电、消费电子、计算机、通讯产品等终端消费品&#xff0c;是这些产品…

python词云图形状修改

python词云图形状修改 词云图介绍wordcloud介绍修改形状参数效果代码 词云图介绍 词云图&#xff08;Word Cloud&#xff09;是一种文本数据的可视化表示形式&#xff0c;它通过字体大小、颜色、布局等视觉元素来展示文本中不同词汇的频率或重要性。词云图中&#xff0c;出现频…