news 2026/4/15 11:44:26

【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/4/14 8:53:33

线下沙龙活动预告:与AI爱好者面对面交流经验

与AI爱好者面对面&#xff1a;深度解析阿里开源语音克隆项目 CosyVoice3 在虚拟主播24小时不间断直播、智能客服能用家乡话和你聊天的今天&#xff0c;你有没有想过——这些“会说话”的AI&#xff0c;是如何学会模仿真人声音的&#xff1f;更进一步&#xff0c;它们能不能只听…

作者头像 李华
网站建设 2026/4/14 19:52:20

版权问题提醒:未经授权不得克隆他人声音商用

版权问题提醒&#xff1a;未经授权不得克隆他人声音商用 在虚拟主播一夜爆红、AI配音悄然渗透影视制作的今天&#xff0c;你有没有想过——那段听起来自然流畅的旁白&#xff0c;真的是真人录的吗&#xff1f;随着语音合成技术突飞猛进&#xff0c;只需几秒钟的声音样本&#x…

作者头像 李华
网站建设 2026/4/14 12:36:02

VS Fish Speech:CosyVoice3情感表达更自然的真实案例对比

VS Fish Speech&#xff1a;CosyVoice3情感表达更自然的真实案例对比 在虚拟主播的直播中&#xff0c;一句“恭喜你中奖了&#xff01;”如果用平淡无波的机械音念出&#xff0c;观众可能毫无反应&#xff1b;但若语气突然变得热情洋溢、语调上扬、节奏轻快——哪怕只是细微的停…

作者头像 李华
网站建设 2026/4/12 11:05:57

微信公众号推文规划:每周一篇深度技术文章

CosyVoice3&#xff1a;3秒克隆你的声音&#xff0c;还能听懂“用四川话说这句话” 你有没有想过&#xff0c;只需要一段3秒钟的录音&#xff0c;就能让AI完美复现你的声音&#xff1f;更进一步——你甚至可以用一句话告诉它&#xff1a;“用悲伤的语气读出来”、“换成粤语”…

作者头像 李华
网站建设 2026/4/11 23:54:10

官方文档之外的学习资源:B站教程与知乎专栏推荐

官方文档之外的学习资源&#xff1a;B站教程与知乎专栏推荐 在短视频和虚拟内容爆发的今天&#xff0c;你有没有想过&#xff0c;只需3秒录音&#xff0c;就能让AI“学会”你的声音&#xff1f;这不再是科幻桥段——阿里达摩院开源的 CosyVoice3 正在把这种能力交到普通人手中。…

作者头像 李华