news 2026/5/31 0:55:33

【C++篇】红黑树的实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【C++篇】红黑树的实现

本篇会用到上篇【AVL树的实现】中的旋转知识。

一,红黑树的概念

红黑树是一颗二叉搜索树,它的每一个节点增加一个存储为来表示节点的颜色。可以是红色或者黑色。它通过对从根开始到叶子节点的每条路径上各个节点颜色的约束,确保最长路径不会超过最短路径的2倍,从而实现平衡的。

1.1,红黑树的规则

1,每个节点不是红色就是黑色。 2,根节点是黑色的。 3,红色节点的两个孩子只能是 黑色节点或者是空节点。也就是说不能出现连续的红色节点 4,对于任意一个节点,从该节点开始,到叶子节点的所有路径上,均包含相同数量的黑色节点。

以上 都是红黑树,满足红黑树的规则。

1.2,红黑树的最长路径

1,由第四条规则可知,从根节点开始的每条路径上,黑色节点的数量相同。所以在极端场景下,一颗红黑树,它的最短路径就是节点全为黑色的路径。假设红黑树的每条路径黑色节点数量都为b,那么最短路径的节点数量为b.

2,由 第三条规则可知,一条路径上不能由连续的红色节点,最长路径是由一黑一红间隔组成的,所以最长路径为2*b。

3,而对于一颗红黑树,最长和最短路径不一定存在。我们可以得出对于任意一颗红黑树,它的任意 一条路径长度x都是,b<=x<=2*b.

1.3,红黑树的效率分析

假设N是红黑树节点的数量,h是最短路径的长度,最长路径不超过2*h

可以得到2^h-1<= N <= 2^(2*h)-1,推出h大致为logN,也就意味着红黑树的增删查该最坏走2*logN,时间复杂度O(logN).

二,红黑树的实现

2.1,红黑树的结构

enum color { Red, Black }; template<class k,class v> struct RBTreeNode { RBTreeNode(const pair<k,v>& kv) :_left(nullptr) ,_right(nullptr) ,_parent(nullptr) ,_kv(kv) {} RBTreeNode<k, v>* _left; RBTreeNode<k, v>* _right; RBTreeNode<k, v>* _parent; pair<k, v> _kv; color _col; }; template<class k,class v> class RBTree { typedef RBTreeNode<k, v> Node; public: //... private: Node* _root=nullptr; };

2.2,红黑树的插入
2.2.1,大致过程

1,插入一个值需要按照搜索树的规则进行插入,再判断插入后是否满足红黑树的规则。2,如果是空树插入,新增节点就是黑色节点。如果是非空树插入,新增节点就必须是红色节点,因为如果插入黑色节点,就一定会破坏规则4,而插入红色节点是有可能会破坏规则3,而且对于规则3来说,解决方法比规则4的解决方法容易。3,非空树插入后,如果父节点是黑色节点,则没有违反任何规则,插入结束。 4,非空树插入后,如果父节点是红色节点,则违反规则3,进一步分析。


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/30 1:48:42

NVIDIA显卡隐藏设置揭秘:5个让游戏性能翻倍的实战技巧

NVIDIA显卡隐藏设置揭秘&#xff1a;5个让游戏性能翻倍的实战技巧 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 还在为NVIDIA官方控制面板功能有限而烦恼&#xff1f;想要深度挖掘显卡潜力却无从下手…

作者头像 李华
网站建设 2026/5/28 9:02:55

iOS微信红包助手2025实测:自动抢红包真的靠谱吗?

iOS微信红包助手2025实测&#xff1a;自动抢红包真的靠谱吗&#xff1f; 【免费下载链接】WeChatRedEnvelopesHelper iOS版微信抢红包插件,支持后台抢红包 项目地址: https://gitcode.com/gh_mirrors/we/WeChatRedEnvelopesHelper "刚刚又错过了一个大红包&#xf…

作者头像 李华
网站建设 2026/5/28 9:02:45

中小学STEAM教育融合:让孩子体验AI语音魅力

让孩子用自己的声音唤醒AI&#xff1a;CosyVoice3如何重塑中小学语音教育 在一间普通的城市小学信息技术课堂上&#xff0c;五年级的学生小林正对着电脑轻声说&#xff1a;“春天来了&#xff0c;花儿都开了。”几秒钟后&#xff0c;音箱里传出了“另一个小林”的声音——用四川…

作者头像 李华
网站建设 2026/5/30 22:40:47

如何上传prompt音频文件到CosyVoice3?WAV/MP3格式要求全解析

如何上传prompt音频文件到CosyVoice3&#xff1f;WAV/MP3格式要求全解析 在AI语音合成技术快速演进的今天&#xff0c;个性化声音克隆已不再是实验室里的概念&#xff0c;而是逐渐走进内容创作、虚拟人交互和智能助手等真实场景。阿里开源的 CosyVoice3 正是这一趋势下的代表性…

作者头像 李华
网站建设 2026/5/28 6:09:47

Telegram群组建立:国际用户沟通桥梁

Telegram群组建立&#xff1a;国际用户沟通桥梁 在全球化协作日益深入的今天&#xff0c;语言不仅是交流的工具&#xff0c;更是文化的载体。然而&#xff0c;在跨国团队、开源社区或跨境服务场景中&#xff0c;我们常常面临这样的困境&#xff1a;一条精心撰写的公告&#xff…

作者头像 李华
网站建设 2026/5/28 6:09:46

豆瓣小组发帖互动:寻找早期种子用户反馈

豆瓣小组发帖互动&#xff1a;寻找早期种子用户反馈 在虚拟主播越来越“像人”、有声书开始拥有专属声线的今天&#xff0c;个性化语音合成早已不再是实验室里的概念。但你有没有遇到过这种情况&#xff1a;明明用的是同一个TTS模型&#xff0c;别人生成的声音惟妙惟肖&#x…

作者头像 李华