文章目录

  • 一、红黑树概念
    • 引申问题
  • 二、红黑树操作

一、红黑树概念

红黑树是一棵二叉搜索树,它在每个节点上增加了一个存储位用来表示节点颜色(红色或者黑色),红黑树通过约束颜色,可以保证最长路径不超过最短路径的两倍,因而近似平衡,而且在实际应用中发现红黑树性能确实比 AVL树性能高

红黑树具有以下性质:

  • 每个节点不是红色就是黑色的
  • 根节点和所有外部节点都是黑色的
  • 根节点到所有外部节点的简单路径上,没有两个连续的红色节点
  • 任一节点到其所有后代外部节点的简单路径上,黑色节点的数量都相同

在这里插入图片描述

引申问题

为什么满足上面的颜色约束性质,红黑树就能保证最长路径不超过最短路径的两倍?
答:最短路径在极端情况下一定是全黑的,假设其数量是 x,而最长路径的黑色节点数量也是 x,并且极端情况下,掺杂的红色节点数量是 x - 1,所以最长路径肯定不超过最短路径的两倍
在这里插入图片描述

二、红黑树操作

查找 + 插入 + 删除

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/93562.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/93562.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/93562.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从0开始跟小甲鱼C语言视频使用linux一步步学习C语言(持续更新)8.14

第十六天 第五十二,五十三,五十四,五十五和五十六集 第五十二集 文件包含 一个include命令只能指定一个被包含文件 文件允许嵌套,就是一个被包含的文件可以包含另一个文件。 文件名可以用尖括号或者双引号括起来 但是两种的查找方…

B+树索引分析:单表最大存储记录数

在现代数据库设计中,随着数据量的增加,如何有效地管理和优化数据库成为了一个关键问题。根据阿里巴巴开发手册的标准,当一张表预计在三年内的数据量超过500万条或者2GB时,就应该考虑实施分库分表策略 Mysql B树索引介绍 及 页内储…

三、memblock 内存分配器

两个问题: 1、系统是怎么知道物理内存的?linux内存管理学习(1):物理内存探测 2、在内存管理真正初始化之前,内核的代码执行需要分配内存该怎么处理? 在Linux内核启动初期,完整的内存…

Python 桌面应用形态后台管理系统的技术选型与方案报告

下面是一份面向“Python 桌面应用形态的后台管理系统”的技术选型与方案报告。我把假设前提→总体架构→客户端技术选型→服务端与数据层→基础设施与安全→交付与运维→质量保障→里程碑计划→风险与对策→最小可行栈逐层给出。 一、前置假设 & 非功能目标 业务假设 典型…

Winsows系统去除右键文件显示的快捷列表

前言:今天重做了电脑系统,安装的是纯净版的系统。然后手动指定D盘安装了下列软件。(QQ,迅雷,百度网盘,搜狗输入法,驱动精灵)然后我右键点击桌面的软件快捷方式,出现了一排…

【Go】Gin 超时中间件的坑:fatal error: concurrent map writes

Gin 社区超时中间件的坑:导致线上 Pod 异常重启 在最近的项目中,我们遇到了因为 Gin 超时中间件(timeout) 引发的生产事故:Pod 异常退出并重启。 问题现场 pod无故重启,抓取标准输出日志,问题…

数据结构:用数组实现队列(Implementing Queue Using Array)

目录 第1步:设计蓝图 (The Struct) 第2步:队列的诞生 (创建与初始化) 第3步:状态检查 (判满与判空) 第4步:核心操作 (入队与出队) 入队 (Enqueue) 出队 (Dequeue) 第5步:善后工作 (销毁队列) 现在,我…

Boost库核心组件与应用

一、BOOST 库简介:C 开发者的 “扩展工具集” 在 C 编程领域,除了标准库(STL)外,BOOST 库是最具影响力的第三方库之一。它由全球数百位开发者共同维护,包含超过 160 个高质量的组件,覆盖从基础…

机器学习 [白板推导](十二)[卡曼滤波、粒子滤波]

15. 线性动态系统(卡曼滤波,Kalman Filter) 15.1. 概述 15.1.1. 背景介绍 变量随时间变化的系统叫做动态系统,其中隐变量取值离散的是隐马尔可夫模型(HMM),而隐变量取值连续的分为线性动态系统…

RH134 访问网络附加存储知识点

1. NFS 的主要功能是什么?答:NFS是一种分布式文件系统协议,主要功能包括:允许远程计算机通过网络访问共享文件。 实现文件系统在客户端和服务器之间的透明访问。支持文件的共享、读取和写入,使得多个 …

组合模式及优化

组合模式是一种结构型设计模式,其核心思想是将对象组合成树形结构,以表示“部分-整体”的层次关系,使得用户对单个对象和组合对象的使用具有一致性。 一、介绍 核心角色 组合模式包含以下3个关键角色: 抽象组件(Compon…

【wmi异常】关于taskkill命令提示“错误:找不到” 以及无法正常获取设备机器码的处理办法

记录一下我的解决方案。 我先查阅了这篇博客:https://blog.csdn.net/qq_45698181/article/details/138957277 发现他写的批处理不知怎么执行不了,后来问了ai又可以执行了,估计是csdn防盗版格式问题 这里写一下我跟ai的对话,大家可…

制造装配、仓储搬运、快递装卸皆适配!MinkTec 弯曲形变传感器助力,让人体工学改变劳动生活

【导语】Minktec 最新实验显示:将Minktec 柔性弯曲形变传感器FlexTail 贴于受试者背部,记录 1 分钟内从洗碗机取餐具的动作,结合配套的flexlib -专用Python库分析,不仅量化出 “越低越伤腰” 的结论,更为制造装配、物流…

Nginx蜘蛛请求智能分流:精准识别爬虫并转发SEO渲染服务

> 一招解决搜索引擎爬虫无法解析现代前端框架的痛点,提升网站收录率与SEO排名! **痛点场景**:你的网站采用Vue/React等前端框架构建,页面内容依赖JavaScript动态渲染。搜索引擎爬虫访问时,只能抓取到空HTML骨架,无法获取真实内容,导致网站收录率低、SEO效果差。 --…

链表。。。

目录 5.1 链表的结点 5.2 插入 5.3 链表长度 5.4 查找 5.5 指定位置删除 5.6 代码 5.1 链表的结点 一个结点包括:值和指向下一个结点的指针。 package com.qcby.链表;public class Node {int value;Node next;public Node(int val){valueval;}Overridepublic…

私人AI搜索新突破:3步本地部署Dify+Ollama+QwQ,搜索能力MAX

1.安装Docker容器 本地部署Dify要先安装Docker桌面版,跟Ollama一样简单,也是去官网下载对应版本文件,直接安装就OK。 2:安装Dify 安装 Dify 简单的方式就是git clone,复制其github地址github.com/langgenius/dify&am…

(2-10-1)MyBatis的基础与基本使用

目录 0.前置小节 1. MyBatis 框架介绍 1.1 软件开发中的框架 1.2 使用框架的好处 1.3 SSM 开发框架 1.4 什么是 MyBatis 1.5 MyBatis 的开发流程 2. MyBatis 的开发流程 2.0 MyBatis的工作流程 2.1 引入 MyBatis 依赖 00.base(目录、pom、单元测试、Junit4) 01.Cal…

StarRocks集群部署

Starrocks 是一款基于 MPP 架构的高性能实时分析型数据库,专为 OLAP(联机分析处理)场景 设计,尤其擅长处理海量数据的实时分析、复杂查询和多维统计。 硬件 CPU:StarRocks依靠AVX2指令集充分发挥其矢量化能力。因此&am…

【CPP】自己实现一个CPP小工具demo,可以扩展其他选项

自己写CPP脚本小工具1. 思路描述2. 代码实现2.1 代码文件CppTool.cpp2.2 CMakeLists.txt3. 工具示例3.1 帮助信息3.2 工具用法3.3 实际使用1. 思路描述 实现一个简单的命令行工具。内容包括: 命令帮助信息参数检查,参数解析等功能。执行其他命令。将指…

如何使用嵌入模型创建本地知识库Demo

为data目录下的txt文档用阿里百炼的文本嵌入模型创建一个本地知识库import os from llama_index.core import ,Settings, SimpleDirectoryReader, VectorStoreIndex from llama_index.core.node_parser import SentenceSplitter from llama_index.llms.dashscope import DashSc…