当前位置: 首页 > news >正文

27.红黑树(上)

从根节点走到空算一条路径,这个有9条路径。最短最长不一定存在。

插入相同节点,avl高度更低,左右很均衡,红黑树不那么均衡,但效率不差,最短路径把他切开,就是满二叉树

avl树比红黑树更接近logN,红黑树比logN多一点,CPU很快没什么差别

h不为0,旋转加变色

变色+继续往上处理,变色要让这棵树之前是一个节点现在还是一个节点,向上处理就是爷爷节点变成红的红的,如果父亲也是红的,连续的红节点,继续处理。

#pragma once enum Colour { RED, BLACK }; template<class K, class V> struct RBTreeNode { // 这里更新控制平衡也要加入parent指针 pair<K, V> _kv; RBTreeNode<K, V>* _left; RBTreeNode<K, V>* _right; RBTreeNode<K, V>* _parent; Colour _col; RBTreeNode(const pair<K, V>& kv) :_kv(kv) , _left(nullptr) , _right(nullptr) , _parent(nullptr) {} }; template<class K, class V> class RBTree { typedef RBTreeNode<K, V> Node; public: bool Insert(const pair<K, V>& kv) { if (_root == nullptr) { _root = new Node(kv); _root->_col = BLACK; return true; } Node* parent = nullptr; Node* cur = _root; while (cur) { if (cur->_kv.first < kv.first) { parent = cur; cur = cur->_right; } else if (cur->_kv.first > kv.first) { parent = cur; cur = cur->_left; } else { return false; } } cur = new Node(kv); cur->_col = RED; if (parent->_kv.first < kv.first) { parent->_right = cur; } else { parent->_left = cur; } // 链接父亲 cur->_parent = parent; // 父亲是红色,出现连续的红色节点,需要处理 while (parent && parent->_col == RED) { Node* grandfather = parent->_parent; if (parent == grandfather->_left) { // g // p u Node* uncle = grandfather->_right; if (uncle && uncle->_col == RED) { // 变色 parent->_col = uncle->_col = BLACK; grandfather->_col = RED; // 继续往上处理 cur = grandfather; parent = cur->_parent; } } else { // g // u p Node* uncle = grandfather->_left; // 叔叔存在且为红,-》变色即可 } } _root->_col = BLACK; return true; }
http://www.cnnetsun.cn/news/38396.html

相关文章:

  • Battery Toolkit:让你的Mac电池寿命延长3年的秘密武器
  • 5分钟掌握SeedVR2-7B:零门槛实现专业级视频修复的完整指南
  • 32、Django Web应用开发实战
  • Blueprint CSS跨浏览器兼容性:打造完美用户体验的终极方案
  • 34、Python 数据持久化:从简单到关系型序列化
  • AFLplusplus深度实战:解锁企业级模糊测试的终极配置
  • 5步掌握Expo项目架构:从零开始构建跨平台应用
  • 14、树莓派的多功能应用:从搭建服务器到控制机器人
  • Aviator预测系统实战指南:从新手到高手的5个关键步骤
  • 16、树莓派的相机应用与外星信号搜索指南
  • 掌握Langflow自定义组件开发与插件集成的完整攻略
  • 【C++】无序容器unordered_set和unordered_map的使用
  • 全面测试QtSql操作PostgreSQL数据库时戳字段的行为
  • 7、深入探索 NCurses 键盘交互:功能与应用
  • 13、NCurses绘图与屏幕数据存储功能详解
  • Apple Safari 26.2 发布 - macOS 专属浏览器 (独立安装包下载)
  • Microsoft System Center 2025 UR1 发布 - Windows 服务器管理软件
  • 从计划到报告:软件测试文档全流程精要
  • StarRocks 2.5.22 混合部署实战文档(CDH环境)
  • 14、深入探索RDF模板与树结构的应用
  • 20、数据到图形的转换:从 XSLT 到交互式可视化
  • Arkime YARA规则实战:构建企业级网络威胁检测体系
  • InfluxDbTemplate使用文档
  • Pyomo优化建模终极指南:从概念到实战应用
  • 开源客服系统终极指南:如何快速部署osTicket提升客户服务效率
  • Qsign签名API:Windows平台QQ机器人验证终极解决方案
  • 74.6%准确率刷新纪录:快手KAT-Dev-72B-Exp重构开源代码生成生态
  • jQuery Mobile滑块组件实战指南:解决移动端触控交互的5大痛点
  • 管家婆软件年结存后快马商城操作注意事项
  • DevToys开发工具箱完全手册:跨平台终极效率提升方案