数据结构(红黑树)

概念

红黑树是一种自平衡的二叉查找树,是计算机科学中用到的一种数据结构。

1972年出现,当时被称之为平衡二叉B树。后来,1978年被修改为如今的"红黑树"

它是一种特殊的二叉查找树,红黑树的每一个节点上都有存储位表示节点的颜色

每一个节点可以是红或者黑;红黑树不是高度平衡的,它的平衡是通过"红黑规则"进行实现的

红黑规则

1.每一个节点或是红色的,或者是黑色的

2.根节点必须是黑色

3.如果一个节点没有子节点或者父节点,则该节点相应的指针属性值为Nǐl,这些Nil视为叶节点,每个叶节点(Nil)是黑色的

4.如果某一个节点是红色,那么它的子节点必须是黑色(不能出现两个红色节点相连的情况)

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

默认颜色:添加节点默认时红色的效率更高

相关推荐
2501_941802487 分钟前
从缓存更新到数据一致性的互联网工程语法实践与多语言探索
java·后端·spring
拆房老料19 分钟前
文档预览开源选型对比:BaseMetas FileView 与 KK FileView,谁更适合你的系统?
java·开源·java-rocketmq·开源软件
Frank_refuel21 分钟前
C++之内存管理
java·数据结构·c++
钱多多_qdd28 分钟前
springboot注解(五)
java·spring boot·后端
2501_9418227534 分钟前
面向灰度发布与风险隔离的互联网系统演进策略与多语言工程实践分享方法论记录思考汇总稿件
android·java·人工智能
@小码农38 分钟前
6547网:202512 GESP认证 C++编程 一级真题题库(附答案)
java·c++·算法
秋938 分钟前
idea中使用AI编程助手Cursor详解
java·intellij-idea·ai编程
q行39 分钟前
java学习日志--IO流(使用)
java·学习·io流
vyuvyucd41 分钟前
Linux线程编程:POSIX与C++实战指南
java·开发语言
菜鸟233号1 小时前
力扣343 整数拆分 java实现
java·数据结构·算法·leetcode