尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

c++红黑树

c++红黑树
📅 发布时间:2026/6/20 7:47:58

一、为什么需要红黑树?

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

  • std::map和std::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::map和std::set默认使用红黑树实现(C++11)。
  • 插入/删除操作时间复杂度为O(log n)。

2.Linux内核

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

3.数据库索引

  • MySQL 的 InnoDB 引擎使用 B+ 树(红黑树的扩展)作为索引结构。

相关新闻

  • Kotaemon能否取代传统聊天机器人?我们做了对比实验
  • Kotaemon框架的测试驱动开发实践
  • EmotiVoice开源项目版本回退策略与风险控制

最新新闻

  • Anthropic的结构性悖论:最担心AI毁灭世界的人,正在亲手建造它
  • vLLM推理性能优化实战:GPUStack+FLASH_ATTN+EvalScope全栈调优
  • 六安市裕安区生日蛋糕推荐去哪家买?5家热门店铺实测对比 - 速递信息
  • 六安市裕安区生日蛋糕推荐去哪家买?5 家热门店铺实测对比 - 速递信息
  • Windows微信QQ防撤回终极指南:技术实现与完整解决方案
  • 3步上手GCP认证:从零基础到专业认证的学习路线图

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号