数据结构 -- 树形查找(三)红黑树

红黑树

为什么要发明红黑树

平衡二叉树AVL:插入/删除很容易破坏平衡性,需要频繁调整树的形态。如:插入操作导致不平衡,则需要先计算平衡因子,找到最小不平衡子树(时间开销大),在进行LL/RR/LR/RL调整

红黑树RBT:插入/删除很多时候不会破坏"红黑"特性,无需频繁调整树的形态。即使需要调整,一般都可以在常数级时间内完成

平衡二叉树:适用于以查为主,很少插入/删除的场景

红黑树:适用于频繁的插入/删除的场景

大概会怎么考?

红黑树的定义和性质 -- 选择题

红黑树的插入/删除 -- 要能手绘插入过程(不太可能考代码),删除操作比较麻烦,也许不考

红黑树的定义和性质

红黑树的定义
c 复制代码
struct RBnode{
    int key;
    RBnode* parent;
    RBnode* lchild;
    RBnode* rchild;
    int color;		//结点颜色,如:可用0/1表示红/黑,也可以使用枚举型enum表示颜色
};

结点的黑高bh -- 从某结点出发(不含该结点)到达任一叶结点的路径上黑节点的总数

红黑树的插入

插入方法

①先查找,确定插入位置(原理同二叉排序树),插入新结点

【与黑高bh相关的推论】

如果根结点的黑高为h,内部结点数(关键字)至少为多少个?

内部结点数最少的情况→总共h层黑结点的满树形态

若根结点黑高为h,内部结点数(关键字)至少有2h-1个

红黑树的删除

重要考点:

①红黑树删除操作的时间复杂度=O(log2n)

②在红黑树中删除结点的处理方式和"二叉排序树的删除'一样

③按②删除结点后,可能破坏"红黑树特性",此时需要调整结点颜色、位置,使其再次满足"红黑树特性"。

相关推荐
郝学胜-神的一滴2 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
不知名XL8 小时前
day50 单调栈
数据结构·算法·leetcode
cpp_250110 小时前
P10570 [JRKSJ R8] 网球
数据结构·c++·算法·题解
cpp_250110 小时前
P8377 [PFOI Round1] 暴龙的火锅
数据结构·c++·算法·题解·洛谷
季明洵10 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
only-qi11 小时前
leetcode19. 删除链表的倒数第N个节点
数据结构·链表
cpp_250111 小时前
P9586 「MXOI Round 2」游戏
数据结构·c++·算法·题解·洛谷
浅念-11 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
爱吃生蚝的于勒11 小时前
【Linux】进程信号之捕捉(三)
linux·运维·服务器·c语言·数据结构·c++·学习
数智工坊12 小时前
【数据结构-树与二叉树】4.6 树与森林的存储-转化-遍历
数据结构