news 2026/4/23 9:20:03

【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/23 9:17:31

自动识别prompt文本错误怎么处理?手动修正CosyVoice3识别内容

自动识别prompt文本错误怎么处理&#xff1f;手动修正CosyVoice3识别内容 在语音合成技术快速普及的今天&#xff0c;声音克隆已不再是实验室里的概念&#xff0c;而是实实在在走进了短视频创作、在线教育、智能客服等日常场景。阿里开源的 CosyVoice3 凭借对普通话、粤语、英语…

作者头像 李华
网站建设 2026/4/17 22:12:18

微信抢红包插件完整使用指南

在热闹的微信群聊中&#xff0c;红包总是让人心动不已。微信抢红包插件作为一款专业的Android自动化工具&#xff0c;能够帮助你在红包活动中抢占先机&#xff0c;轻松收获满满的惊喜。无论你是技术爱好者还是普通用户&#xff0c;这款免费插件都能为你带来前所未有的抢红包体验…

作者头像 李华
网站建设 2026/4/19 3:09:00

解放双手的智能助手:B站视频一键转文字全攻略

解放双手的智能助手&#xff1a;B站视频一键转文字全攻略 【免费下载链接】bili2text Bilibili视频转文字&#xff0c;一步到位&#xff0c;输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 你是否曾经为了整理视频中的精彩内容而耗费大量时间…

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

身份认证机制扩展:添加用户名密码登录保护

身份认证机制扩展&#xff1a;添加用户名密码登录保护 在AI语音合成技术迅猛发展的今天&#xff0c;像阿里开源的CosyVoice3这样的声音克隆系统正变得越来越普及。它支持普通话、粤语、英语以及18种中国方言的情感化语音生成&#xff0c;具备极强的表现力和个性化能力。这类系统…

作者头像 李华
网站建设 2026/4/23 9:19:58

IoT设备语音升级:低成本实现个性化的语音播报功能

IoT设备语音升级&#xff1a;低成本实现个性化的语音播报功能 在智能音箱能叫你起床、扫地机器人会撒娇卖萌的今天&#xff0c;用户早已不满足于“滴——水温正常”这种机械提示音。他们想要的是有温度的声音&#xff0c;是奶奶念睡前故事的语调&#xff0c;是用四川话喊一声“…

作者头像 李华
网站建设 2026/4/17 8:09:55

电子书免费领取活动:《精通CosyVoice3》限时下载

CosyVoice3&#xff1a;当声音克隆走进千人千声时代 在短视频创作者为角色配音焦头烂额、客服系统因“机械音”被用户投诉、方言节目制作团队苦于找不到合适播音员的今天&#xff0c;一种新的技术正在悄然改变语音生成的规则——只需3秒人声样本&#xff0c;就能复刻出高度拟真…

作者头像 李华