news 2026/5/6 23:15:37

c++红黑树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
c++红黑树

一、为什么需要红黑树?

在编程中,我们经常需要一个动态维护有序数据的结构。比如:

  • std::mapstd::set的底层实现
  • Linux内核的进程调度器
  • 数据库的索引结构

如果使用普通的二叉搜索树(BST),极端情况下会退化成链表(如插入有序数据),导致查找效率从O(log n)降为O(n)。为了解决这个问题,红黑树(Red-Black Tree)应运而生。

二、红黑树的核心思想

红黑树是一种自平衡的二叉搜索树,它通过以下规则实现近似平衡:

红黑树的5大规则

  1. 每个节点非红即黑
  2. 根节点必须是黑色
  3. 红色节点的子节点必须是黑色(不能出现连续的红色)
  4. 从任意节点到其空子节点的路径上,黑色节点的数量必须相同
  5. 每个叶子节点(空节点)是黑色

为什么这些规则能保证效率?

  • 最长路径 ≤ 2 × 最短路径
    例如,如果最短路径有k个节点,最长路径最多有2k个节点。这确保了红黑树的高度始终在O(log n)范围内。

三、红黑树的插入操作详解

插入新节点时,红黑树需要通过变色 + 旋转维持平衡。以下是典型场景:

情况1:父节点是黑色

  • 直接插入即可,无需调整。

情况2:父节点是红色

此时需要根据叔叔节点的颜色进行处理:

子情况1:叔叔是红色
  • 操作:父节点、叔节点变黑,祖父节点变红,并继续向上处理。
祖父(黑) → 父(红) → 当前(红) 叔(红)
子情况2:叔叔是黑色或不存在

需要通过旋转调整:

  • LL型(当前节点在左子树的左子树):右单旋 + 变色
  • RR型(当前节点在右子树的右子树):左单旋 + 变色
  • LR型(当前节点在左子树的右子树):左右双旋 + 变色
  • RL型(当前节点在右子树的左子树):右左双旋 + 变色

四、红黑树的代码实现

enum Color { RED, BLACK }; template <typename K, typename V> struct RBTreeNode { RBTreeNode* left; RBTreeNode* right; RBTreeNode* parent; std::pair<K, V> kv; Color color; RBTreeNode(const K& key, const V& value) : left(nullptr), right(nullptr), parent(nullptr), kv(key, value), color(RED) {} }; template <typename K, typename V> class RBTree { public: void insert(const K& key, const V& value) { // 二叉搜索树插入逻辑 // ... // 插入后调整平衡 fixInsert(newNode); } private: void fixInsert(RBTreeNode<K, V>* node) { while (node->parent && node->parent->color == RED) { // 处理四种情况 // ... } root->color = BLACK; } RBTreeNode<K, V>* root; };

五、红黑树的应用场景

1.C++ STL容器

  • std::mapstd::set默认使用红黑树实现(C++11)。
  • 插入/删除操作时间复杂度为O(log n)

2.Linux内核

  • 完全公平调度器(CFS)使用红黑树管理进程队列。
  • 快速找到下一个要运行的进程。

3.数据库索引

  • MySQL 的 InnoDB 引擎使用 B+ 树(红黑树的扩展)作为索引结构。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/5 8:53:35

Kotaemon负载均衡部署方案建议

Kotaemon负载均衡部署方案建议 在企业智能化转型加速的今天&#xff0c;越来越多组织开始构建基于大语言模型的知识助手和客服系统。然而&#xff0c;当这些系统从原型走向生产环境时&#xff0c;一个关键问题浮出水面&#xff1a;如何让智能问答服务在高并发场景下依然稳定、快…

作者头像 李华
网站建设 2026/5/4 16:42:23

18、多种操作系统在虚拟机中的安装与配置指南

多种操作系统在虚拟机中的安装与配置指南 在虚拟机环境中安装和配置不同的操作系统,能够为用户提供多样化的使用体验和测试平台。下面将详细介绍NetBSD、OpenBSD、Novell Netware和Solaris等操作系统在VMware中的安装、设备配置以及内核管理等方面的内容。 1. NetBSD安装与配…

作者头像 李华
网站建设 2026/5/5 8:20:30

4、开启 Ubuntu 之旅:从硬件准备到系统安装

开启 Ubuntu 之旅&#xff1a;从硬件准备到系统安装1. 硬件兼容性与要求在安装 Ubuntu 之前&#xff0c;我们需要先确认硬件的兼容性&#xff0c;并了解硬件的基本要求。1.1 检查硬件兼容性要查看主板型号&#xff0c;通常可以在主板的中间或边缘找到相关信息。例如&#xff0c…

作者头像 李华
网站建设 2026/5/5 2:30:55

EmotiVoice如何生成权威感十足的新闻播报语音?

EmotiVoice如何生成权威感十足的新闻播报语音&#xff1f; 在主流媒体加快智能化转型的今天&#xff0c;一条突发新闻从发生到全网传播&#xff0c;往往只需几分钟。而在这背后&#xff0c;越来越多的声音并非来自真人主播——而是由AI驱动的虚拟播报系统自动生成。这些语音不仅…

作者头像 李华
网站建设 2026/4/23 17:51:02

RN Navigation vs Vue Router 的架构对比

[toc] 很多团队同时做 Web 和 RN&#xff0c;经常会问&#xff1a;“能不能把 Web 的路由思想用到 RN&#xff1f;”答案是&#xff1a;能&#xff0c;但不能照抄。 一、本质差异先搞清楚维度Vue RouterRN Navigation渲染模型URL 驱动Stack 驱动页面状态可刷新内存状态回退机制…

作者头像 李华
网站建设 2026/5/4 16:19:04

20、量子退火在机器学习分类任务中的应用

量子退火在机器学习分类任务中的应用 在当今的科技领域,量子退火技术正逐渐成为优化机器学习分类器的有力工具。本文将深入探讨量子退火在机器学习分类任务中的应用,介绍不同领域的相关研究工作,并分析其优势和挑战。 1. 量子退火与D-Wave系统 量子退火是一种利用量子力学…

作者头像 李华