全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

c++如何实现红黑树算法_c++ 数据结构定义与节点旋转逻辑【详解】

红黑树节点必须包含颜色字段和父指针;旋转需更新四元组父子关系;插入修复分四类case处理;删除复杂,建议优先使用std::map/set。

红黑树节点定义必须包含颜色字段和三叉指针

标准二叉搜索树节点不满足红黑树约束,RBNode 必须显式存储颜色(通常用 bool is_red 或枚举),且需保留父指针——这是实现自底向上修复旋转的前提。子节点指针命名建议统一为 leftright,避免用 lchild 等非主流写法导致后续逻辑混乱。

常见错误:漏掉 parent 指针,导致插入后无法回溯调整;或把颜色存在 int color 里却未定义 RED=0/BLACK=1,引发条件判断歧义。

struct RBNode {
    int key;
    bool is_red;  // true 表示红色,false 表示黑色
    RBNode* left;
    RBNode* right;
    RBNode* parent;
RBNode(int k) : key(k), is_red(true), left(nullptr), right(nullptr), parent(nullptr) {}

};

左旋与右旋函数必须更新父子关系四元组

旋转不是单纯交换指针,而是重连 old_rootnew_rootsubtreeparent 四者之间的 left/right/parent 字段。漏掉任一链接(尤其是 new_root->parentold_root->parent)都会导致树断裂或内存泄漏。

立即学习“C++免费学习笔记(深入)”;

  • left_rotate(x):以 x 为轴,将 x->right 提升为新根,x 成为其左子
  • right_rotate(y):以 y 为轴,将 y->left 提升为新根,y 成为其右子
  • x 是根节点,旋转后需同步更新树的 root 指针
void left_rotate(RBNode*& root, RBNode* x) {
    RBNode* y = x->right;
    x->right = y->left;
    if (y->left != nullptr) y->left->parent = x;
y->parent = x->parent;
if (x->parent == nullptr) {
    root = y;
} else if (x == x->parent->left) {
    x->parent->left = y;
} else {
    x->parent->right = y;
}

y->left = x;
x->parent = y;

}

插入后修复需分四类 case 处理,核心是变色+旋转组合

插入新节点默认设为红色,仅可能违反「红节点不能有红子」和「根必须为黑」两条规则。修复函数 insert_fixup 从新节点开始向上迭代,关键在于识别当前节点 z、父节点 z->parent、叔节点 uncle 的颜色组合:

  • Case 1:叔节点为红 → 父与叔变黑,祖父变红,z = z->parent->parent 继续向上检查
  • Case 2:叔为黑且 z 是右子 → 先 left_rotate(z->parent),转为 Case 3
  • Case 3:叔为黑且 z 是左子 → right_rotate(z->parent->parent),再将父变黑、祖父变红
  • 注意:所有旋转后必须立即修正颜色,且 Case 1 中若祖父为根,则最后一步需强制置黑

容易被忽略的点:uncle 判空必须用 uncle == nullptr 而非 !uncle(避免未初始化野指针误判);修复循环终止条件是 z->parent == nullptr || !z->parent->is_red

删除操作比插入复杂得多,建议优先复用 std::map/set

红黑树删除涉及「找后继→替换→修复双黑」三阶段,修复逻辑包含至少 6 种 case,其中「双黑传播」需同时处理兄弟颜色、兄弟子节点颜色、兄弟是否为根等交叉条件。手动实现极易在边界场景(如删根、删唯一子树、连续黑节点)出错。

除非教学目的或嵌入式环境严格限制 STL,否则直接使用 std::mapstd::set 更可靠——它们底层就是红黑树,接口稳定,且经过数十年编译器厂商验证。自己造轮子时,务必用大量随机序列 + valgrind 检查内存泄漏和非法访问。


# node  # c++  # red  # bool  # int  # 循环  # 指针  # 数据结构  # 接口  # map  # 算法  # 红黑  # 子树  # 四类  # 变黑  # 变红  # 这是  # 尤其是  # 设为  # 得多  # 能有 


相关文章: 制作网站的软件免费下载,免费制作app哪个平台好?  如何用好域名打造高点击率的自主建站?  建站之星如何快速生成多端适配网站?  香港服务器WordPress建站指南:SEO优化与高效部署策略  h5网站制作工具有哪些,h5页面制作工具有哪些?  制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?  营销式网站制作方案,销售哪个网站招聘效果最好?  如何设置并定期更换建站之星安全管理员密码?  如何快速搭建响应式可视化网站?  建站之星CMS五站合一模板配置与SEO优化指南  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  动图在线制作网站有哪些,滑动动图图集怎么做?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何批量查询域名的建站时间记录?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  学校建站服务器如何选型才能满足性能需求?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  零基础网站服务器架设实战:轻量应用与域名解析配置指南  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  建站之星如何快速更换网站模板?  如何在IIS中新建站点并解决端口绑定冲突?  建站10G流量真的够用吗?如何应对访问高峰?  西安专业网站制作公司有哪些,陕西省建行官方网站?  如何快速生成凡客建站的专业级图册?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  如何快速生成可下载的建站源码工具?  建站主机类型有哪些?如何正确选型  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  微信推文制作网站有哪些,怎么做微信推文,急?  C++如何使用std::optional?(处理可选值)  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  建站主机默认首页配置指南:核心功能与访问路径优化  上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?  5种Android数据存储方式汇总  Python lxml的etree和ElementTree有什么区别  学校为何禁止电信移动建设网站?  如何快速重置建站主机并恢复默认配置?  如何续费美橙建站之星域名及服务?  如何在建站主机中优化服务器配置?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  如何自定义建站之星模板颜色并下载新样式?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  威客平台建站流程解析:高效搭建教程与设计优化方案  建站之星导航配置指南:自助建站与SEO优化全解析  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  如何快速查询域名建站关键信息?  建站之星如何助力企业快速打造五合一网站?  装修招标网站设计制作流程,装修招标流程? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。