【C++学习篇】红黑树 从入门到进阶

目录

1.红黑树的概念

1.1红黑树的规则

1.2红黑树的效率

[2. 红黑树的实现](#2. 红黑树的实现)

[2.1 红黑树的结构](#2.1 红黑树的结构)

2.2红黑树的插入

2.2.1红黑树插入,旋转的一些细节

[2.2.1.1 u(uncle)不存在 ,c为p的左孩子(单旋+变色)](#2.2.1.1 u(uncle)不存在 ,c为p的左孩子(单旋+变色))

[2.2.1.2 uncle存在且为黑,c为p的左孩子(单旋+变色)](#2.2.1.2 uncle存在且为黑,c为p的左孩子(单旋+变色))

[2.2.1.3 u(uncle)不存在 ,c为p的右孩子(双旋+变色)](#2.2.1.3 u(uncle)不存在 ,c为p的右孩子(双旋+变色))

2.3插入节点的代码实现

[3. 本期关于红黑树的总结:](#3. 本期关于红黑树的总结:)


1.红黑树的概念

红黑树是一棵二叉搜索树,但是在此基础之上,又增加了一个存储为来表示节点的颜色,可以是红色或者是黑色。通过对任意一条根到叶子的路径上的各个节点的颜色来进行约束,红⿊树确保没有⼀条路径会⽐其他路径⻓出2倍,因⽽是接近平衡的。

1.1红黑树的规则

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

2.根结点是⿊⾊的。

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

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

(则说明,假设一条路径有n个黑节点,且全为黑,没有红,则该条路径最短;则最长路径肯定是一黑一红交替出现,因为红节点不能连续出现,所以最长路径节点数是2n。!!最短路径和最长路劲不一定存在,我这里只是做一个讲解。)

1.2红黑树的效率

假设N是红⿊树树中结点数量,h最短路径的⻓度,那么 2h − 1 <= N < 22∗h − 1 , 由此推出

h ≈ logN ,也就是意味着红⿊树增删查改最坏也就是⾛最⻓路径 2 ∗ logN ,那么时间复杂度还是

O(logN ) 。

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

2. 红黑树的实现

2.1 红黑树的结构

2.2红黑树的插入

2.2.1红黑树插入,旋转的一些细节

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

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

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

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

  4. ⾮空树插⼊后,新增结点必须红⾊结点,如果⽗亲结点是红⾊的,则违反规则3。进⼀步分析,c是红⾊,p为红,g必为⿊,这三个颜⾊都固定了,关键的变化看u的情况,需要根据u分为以下⼏种情况分别处理。

2.2.1.1 u(uncle)不存在 ,c为p的左孩子(单旋+变色)
2.2.1.2 uncle存在且为黑,c为p的左孩子(单旋+变色)
2.2.1.3 u(uncle)不存在 ,c为p的右孩子(双旋+变色)

2.2.1.4 uncle存在且为黑,c为p的右孩子(双旋+变色)

2.3插入节点的代码实现

3. 本期关于红黑树的总结:

我觉得有一些难度,特别是在选旋转这里,要不是我为了写博客,在上完课之后,又梳理了一边。整体将清楚的结构写了下来,希望对大家有真的帮助。

相关推荐
蜕变菜鸟几秒前
JS的Object.keys()和sort()排序的用法
数据结构·算法
源代码•宸1 分钟前
Golang基础语法(go语言error、go语言defer、go语言异常捕获、依赖管理、Go Modules命令)
开发语言·数据库·后端·算法·golang·defer·recover
CSDN_RTKLIB4 分钟前
CMake构建目标核心命令
c++
郝学胜-神的一滴5 分钟前
图形学中的纹理映射问题:摩尔纹与毛刺的深度解析
c++·程序人生·unity·游戏引擎·图形渲染·unreal engine
镜中人★11 分钟前
408数据结构考纲知识点(更新中)
数据结构
如果你想拥有什么先让自己配得上拥有11 分钟前
算数顺序的逻辑和发展?
算法
Cx330❀24 分钟前
【优选算法必刷100题】第43题(模拟):数青蛙
c++·算法·leetcode·面试
杜子不疼.24 分钟前
【LeetCode30_滑动窗口 + 哈希表】:三招搞定“串联所有单词的子串”
数据结构·算法·哈希算法
闻缺陷则喜何志丹24 分钟前
【C++动态规划 状压dp】1879. 两个数组最小的异或值之和|2145
c++·算法·动态规划·力扣·数组·最小·动态规范
艾莉丝努力练剑29 分钟前
【优选算法必刷100题:专题五】(位运算算法)第033~38题:判断字符是否唯一、丢失的数字、两整数之和、只出现一次的数字 II、消失的两个数字
java·大数据·运维·c++·人工智能·算法·位运算