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

红黑树的插入 C++

红黑树与二叉搜索树类似

它在每个节点增加了一个存储位记录节点的颜色,可以是RED,也可以是BLACK;通过任意一条从根到叶子简单路径上颜色的约束,红黑树保证最长路径不超过最短路径的二倍,因而近似平衡(最短路径就是全黑节点,最长路径就是一个红节点一个黑节点,当从根节点到叶子节点的路径上黑色节点相同时,最长路径刚好是最短路径的两倍)。它同时满足以下特性:

1.节点是红色或黑色
2.根是黑色
3.叶子节点(外部节点,空节点)都是黑色,这里的叶子节点指的是最底层的空节点(外部节点),下图中的那些null节点才是叶子节点,null节点的父节点在红黑树里不将其看作叶子节点
红色节点的子节点都是黑色
4.红色节点的父节点都是黑色
5.从根节点到叶子节点的所有路径上不能有 2 个连续的红色节点
6.从任一节点到叶子节点的所有路径都包含相同数目的黑色节点

现在我们进行对红黑数的插入

enum Colour
{BLACK,RED,
};
template<class K, class V>
class RBTreeNode
{RBTreeNode<K, V>* _left;RBTreeNode<K, V>* _right;RBTreeNode<K, V>* _parent;pair<K, V>_kv;Colour _col;
};template<class K, class V>
class RBtree
{typedef RBTreeNode<K, V>Node; public:bool Insert(const pair<K, V>& kv){//1.按搜索树的规则进行插入if (!_root){_root = new Node(kv);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);if (parent->_kv.first < kv.first){parent->_right=cur;cur->_parent = parernt;}else{parent->left = cur;cur->_parent=parent;}//新增节点红的cur->_col = RED;while (parent->_col == RED){//红黑树的调节关键看父节点的另一个节点Node* grandfather = parent->_parent;if (grandfather->_left == parent){Node* uncle = grandfather->_right;//情况一:uncle存在且为红if (uncle && uncle->_col == RED){parent->_col = uncle->_col = BLACK;grandfather->_col = RED;//继续往上处理cur = grandfather;parent = cur->_parent;}//情况二:uncle不存在或为黑else{//情况三:双旋—>单旋if (cur==parent->_right){RotateL(parent);//左旋swap(parent, cur);}RotateR(grandfather);grandfather->_col = RED;parent->_col = BLACK;break;}}else{Node* uncle = grandfather->_right;//情况一:uncle存在且为红if (uncle && uncle->_col == RED){parent->_col = uncle->_col = BLACK;grandfather->_col = RED;//继续往上处理cur = grandfather;parent = cur->_parent;}//情况二:uncle不存在或为黑else{//情况三:双旋—>单旋if (cur == parent->_right){RotateR(parent);swap(parent, cur);}RotateL(grandfather);grandfather->_col = RED;parent->_col = BLACK;break;}}}root->_col = BLACK;return true;}private:Node* _root = nullptr;
};


http://www.mrgr.cn/news/19187.html

相关文章:

  • Spring 源码解读:自定义依赖注入机制与其核心原理
  • python办公自动化:使用`Python-PPTX`的样式与格式
  • minio存储照片
  • 自动生成对话视频!如何使用Captions的AI视频生成与编辑API工具?
  • Nature:最大扩散强化学习
  • 实习的一点回顾Webhook的执行
  • 天津自学考试转考流程及免冠照片处理方法说明
  • 基于深度学习的对抗样本生成与防御
  • Linux日志-wtmp日志
  • DPDK基础入门(二):Cache与大页优化
  • 哈希:哈希函数 | 哈希概念 | 哈希冲突 | 闭散列 | 开散列
  • YOLOv8改进实战 | 引入多维协作注意模块MCA,实现暴力涨点
  • ARM基础---编程模型---ARM汇编
  • 传统CV算法——特征匹配算法
  • 性能测试⼯具-——JMeter
  • Go 语言 API 开发
  • Vue3中使用@作为引用根目录报错
  • 嵌入式:Arm v7-M指令集架构中的字节序(大小端)
  • 揭秘推荐算法:深度学习如何读懂你的购物心思
  • house of cat