C++之红黑树

server/2024/11/17 1:13:49/

红黑树的概念

红黑树是一种二叉搜索树,在每个节点上增加一个储存位代表节点的颜色,可以是黑色或者是红色。通过对任何一条从根节点到叶子节点的路径上节点颜色的限制,红黑树可以保证没有一条路径会比其他路径长两倍,由此接近平衡。

红黑树的性质

1.每个节点不是红色就是黑色

2.根节点是黑色的

3.如果一个节点是红色,那么它的孩子节点是黑色

4.对于每个节点,从该节点到其所有后代节点的简单路径上,均包含相同数目的黑色节点

5.每个叶子节点都是黑色的(在这里叶子节点指根节点)

红黑树节点的定义

包含左孩子,右孩子,双亲,值域,节点

红黑树的结构

在红黑树钟增加一个头节点,将头节点给成黑色,让头节点的pParent指向红黑树的根节点,pLeft指向红黑树的最小节点,pRight指向红黑树的最大节点

红黑树的插入操作

红黑树实在二叉搜索树的基础上加上限制平衡的条件,所以可以分为两步

1.按照二叉搜索树的规则插入新的节点

2.检测新节点插入后,红黑树的性质是否被破坏

1)新节点默认颜色为红色,如果双亲的颜色是黑色,就没有违反红黑树的规则,不需要进行调整

2)新节点插入节点的双亲为红色时,就违反了红色节点的孩子节点只能为黑色的规则

这个时候,就要分三种情况进行讨论

->第一种情况,cur为红,p为红,g为黑,u存在且为红

解决方式是将p,u改为黑色,g改为红色,然后把g当作cur,继续向上调整

->cur为红,p为红,g为黑,u不存在或者u存在且为黑

u的情况有两种

【1】u节点不存在,cur一定是新插入节点

【2】u节点存在,它一定是黑色的,cur节点原来的颜色一定是黑色的

解决方式

p为g的左孩子,cur为p的左孩子,则进行右单旋;

p为g的右孩子,cur为p的右孩子,则进行左单旋;

p变黑,g变红

->cur为红,p为红,g为黑,u不存在或者u存在且为黑

p为g的左孩子,cur为p的右孩子,则对p进行左单旋;

p为g的右孩子,cur为p的左孩子,则对p进行右单旋;

操作以后就转化为了情况二

红黑树的验证

验证分为两个部分

1.是否满足搜索二叉树性质

2.是否满足红黑树的性质

红黑树的删除

。。。

红黑树与AVL树的比较

红黑树与AVL的增删查改的时间复杂度都是O(log(N)),红黑树不追求绝对的平衡,所以性能更优

红黑树的应用

1.C++的STL(比如map/set,multiset/multimap)

2.。。。

红黑树的迭代器

1.begin()与end()

begin可以是红黑树的最小节点,end是红黑树最大节点的下一个位置

由于end不能为空(因为进行--操作要找点最大节点),所以让end为红黑树的头节点

2.operator++与operator--

->关于operator++,分两种情况,若右子树存在,找右子树的最左节点。若右子树不存在,继续向上查找,直到该节点不为双亲节点的右节点

->关于operator--,分三种情况

pNode在head节点的位置,那么--操作后,指向树中的最大节点;

pNode的左子树存在,--操作后为左子树的最右节点

pNode的左子树不存在,就一直向上找

改造红黑树

1.valuetype:如果是map,就是pair<k,v>类型,如果是set,就是k类型

2.keyOfvalue:通过value来获取key的一个仿函数类

map的模拟实现

在map中封装红黑树

set的模拟实现

在set中封装红黑树


http://www.ppmy.cn/server/142516.html

相关文章

python爬虫初体验(五)—— 边学边玩小游戏

1. 打开浏览器 利用webbrowser 模块的 open()函数可以启动一个新浏览器&#xff0c;打开指定的 URL。 import webbrowser webbrowser.open(http://inventwithpython.com/) 2. 猜数字游戏 # -*- coding: utf-8 -*- # This is a guess the number game. import randomsecretN…

构建Spring Boot编程训练系统:全面指南

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理编程训练系统的相关信息成为必然。开发合适…

STM32芯片EXIT外部中断的配置与原理以及模板代码(标准库)

配置EXIT外部中断其实就是把GPIO刀NVIC的各个外设配置好 第一步&#xff1a;配置RCC&#xff0c;把我们涉及到的外设的时钟都打开 &#xff08;此处EXTI是默认打开的&#xff0c;而NVIC是内核外设无需配置&#xff09; 第二步&#xff1a;配置GPIO,选择端口为输入模式 第三…

python遇到问题

1&#xff0c;BeautifulSoup lxml 解析器安装 问 1&#xff0c;BeautifulSoup lxml 解析器安装2&#xff0c;BeautifulSoup 如何引入第三方库 BeautifulSoup lxml&#xff0c;默认是导入的是python内置的解析器答1 1. 安装 Python 和 pip 确保你已经安装了 Python 和 pip。你…

JVM——类加载器、类加载器的分类

类加载器是java虚拟机提供给应用程序去 实现获取类和接口字节码数据 的技术 类加载器的分类&#xff1a; 一类是 Java代码中实现的一类是 Java虚拟机底层源代码实现的 通常可以细分为三大类&#xff1a;jdk8版本中的 java代码中的 扩展类加载器&#xff1a;Extension 允许扩…

力扣-Mysql-3322- 英超积分榜排名 III(中等)

一、题目来源 3322. 英超积分榜排名 III - 力扣&#xff08;LeetCode&#xff09; 二、数据表结构 表&#xff1a;SeasonStats --------------------------- | Column Name | Type | --------------------------- | season_id | int | | team_id …

Element-ui Select选择器自定义搜索方法

效果图 具体实现 <template><div class"home"><el-selectref"currencySelect"v-model"currency"filterable:spellcheck"false"placeholder"请选择":filter-method"handleCurrencyFilter"change&q…

刷题统计(C语言)

问题描述 小明决定从下周一开始努力刷题准备蓝桥杯竞赛。他计划周一至周五每天 做 aa 道题目, 周六和周日每天做 bb 道题目。请你帮小明计算, 按照计划他将在 第几天实现做题数大于等于 nn 题? 输入格式 输入一行包含三个整数 a,ba,b 和 nn. 输出格式 输出一个整数代表天…