news 2026/2/9 4:40:14

数据结构:二叉排序树,平衡二叉树,红黑树的介绍

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构:二叉排序树,平衡二叉树,红黑树的介绍

一.二叉排序树

二叉排序树的定义是任意一个父节点的值,大于其左子树节点的值,小于其右子树节点的值。

以下是两个例子:

(1)数组:5,3,1,4,8,9,7

它的二叉排序树是这样的:

它的时间复杂度是O(logn)。

(2)数组:1,2,3

它的二叉排序树是这样的:

它的时间复杂度是O(n)。

由此可见,两种情况下的二叉排序树的时间复杂度不同,因此,二叉排序树是不稳定的

当树的结构完全平衡时(如红黑树),节点数 n 与高度 h 的关系为h = logn。此时核心操作的时间复杂度为O(log n),这是二叉排序树的最优性能。
当节点按升序或降序插入时,二叉排序树会退化为一条单链(每个节点只有左子树或只有右子树)。此时树的高度h = n,核心操作的时间复杂度退化为O(n)

为了解决这种不平衡的现象,引入了一种更先进的树,名为平衡二叉树。


二.平衡二叉树

平衡二叉树在排序二叉树的基础上,要求左右子树高度差的绝对值不能超过 1(小于等于 1)。

如果这个树不平衡了,我们应该怎么调节?于是引入了4种平衡化调整策略。

(1)LL型

这是调节前的树:

这是调节后的树:

技巧:让不平衡节点朝着造成不平衡的节点走两步,盯着不平衡主链,让中间节点成为新的父节点,其余节点按照顺序进行插入。

(2)RR型

这是调节前的树:

这是调节后的树:

整体方法和LL型类似。

(3)LR型

这是调节前的树:

这是调节后的树:

技巧:

还是先让不平衡节点朝着造成不平衡的节点走两步,

然后盯着不平衡主链,采用两步旋转法:

第一步:后二整体旋转(把造成不平衡的点和它的父节点调换顺序,并变成LL/RR型

第二步:采用LL/RR旋转

(4)RL型

这是调节前的树:

后二整体旋转之后的树:

这是调节后的树:

整体和LR型类似。

其实,平衡二叉树也是有缺点的,它过分追求时间复杂度的完美,导致旋转过程会消耗大量的计算机资源

于是引入了一个性能更好的树,名为红黑树。


三.红黑树

在介绍红黑树之前,要先了解一下2-3-4树(4阶B树),因为2-3-4树与红黑树是等价的数据结构,它们之间可以相互转换。

(1)2-3-4树的特点与插入操作

2-3-4树每种节点的结构:

特性:每个节点的关键字都是有序排列的,且左子树的所有关键字小于根节点关键字,右子树的所有关键字大于根节点关键字。所有叶子节点都在同一层,保证了树的高度平衡。

插入操作:首先从根节点开始查找插入位置,找到合适的叶子节点后插入新关键字。如果插入后该节点的关键字数量超过 3 个(即成为 4 - 节点),则需要进行分裂操作。将 4 - 节点中间的关键字提升到父节点,左右两边的关键字分别形成两个新节点。如果父节点也因此变得满了(成为 4 - 节点),则需要递归地对父节点进行分裂操作。

(2)2-3-4树到红黑树的转换

首先我们先了解一下2-3-4树与红黑树各种节点的对应样式:

下图是一个2-3-4树:

然后找到各节点对应的红黑树样式,2节点对应一个黑节点,3节点对应父节点是黑节点,下面接一个红结点,4节点对应父节点是黑节点,下面左右节点都是红结点

调整好之后如下图所示:

(每个最下方的节点下面都有一个黑色的叶子结点,图中没有画出来)

(3)红黑树的特点

1.红黑树的节点颜色不是红色就是黑色的。
2.根节点一定是黑色的。
3.叶子节点也是黑色的(上面那张图每个最下方的节点下面都有一个黑色的叶子结点,图中没有画出来)。
4.如果一个节点是红色的,那么他的子节点一定是黑色的。
5.从根节点出发到任意的一个叶子节点,所走过的路径上黑色节点的数目是相同的。

从特点中还可以得出一个结论:红黑树当中最长的链条不会超过最短链条的 2 倍。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/8 0:09:55

技术架构的核心目标

技术架构的核心问题与目标 技术架构的核心在于解决系统在物理层面的稳定性、性能和扩展性问题,确保业务功能在复杂环境下可靠运行。以下是技术架构需重点解决的问题及实现目标:系统的物理组成 一个完整的系统由多个层级构成: 接入系统&#x…

作者头像 李华
网站建设 2026/2/7 10:34:20

算法导论第三版,学习日志,2.思考

2-1 (在归并排序中对小数组采用插入排序)虽然归并排序的最坏情况运行时间为 Θ(n lg n),而插入排序的最坏情况运行时间为 Θ(n),但是插入排序中的常量因子可能使得它在 n 较小时,在许多机器上实际运行得更快。因此&…

作者头像 李华
网站建设 2026/2/5 13:57:17

Python数据类型入门

引言 在Python编程中,数据类型就像“食材”,掌握它们才能做出美味的“代码大餐”。今天我们用生活中的例子,带大家认识Python最常用的6种数据类型,看完就能动手写代码! 一、整数与浮点数:数字的两种形态 整…

作者头像 李华
网站建设 2026/2/5 20:17:53

基于遗传算法的多式联运车辆路径网络优优化研究附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎 往期回顾关注个人主页:Matlab科研工作室 🍊个人信条:格物致知,完整Matlab代码及仿真…

作者头像 李华
网站建设 2026/2/5 12:10:30

折叠与影像:高端手机技术演进的两大方向

每当为大家提供丰富选择的每年购物季时段来临之际,高端手机市场无一例外地都会出现新品发布会密集举行以及价格作出调整的情况。众多旗舰机型之中可以发现存在两个备受关注的技术方向,其中一个是折叠屏方向,另一个是影像旗舰方向,…

作者头像 李华