Inline void __rb_tree_rebalance(__rb_tree_node_base* x, __rb_tree_node_base*& root)  //当前节点,根

{
x->color = __rb_tree_red; //新插入的节点必然为红色,之后可以再调整颜色
while(x != root && x->parent->color == _rb_tree_red) //父节点为红色,发生了冲突
{
//还考虑了x!=root这个边界情况
If(x->parent == x->parent->parent->left)
//判断父节点是不是为祖先节点的左节点
{
__rb_tree_node_base* y = x->parent->parent->right;
/**取得伯父节点,后面根据伯父节点来操作
下面分6种情况介绍红黑树的插入操作:
1 插入点的父亲为红,父亲的兄弟节点为黑,插入点在外侧
2 插入点的父亲为红,父亲的兄弟节点为黑,插入点在内侧
3 插入点的父亲为红,父亲的兄弟节点为红,插入点在外侧
4 插入点的父亲为红,父亲的兄弟节点为红,插入点在外侧(父亲的祖父节点为红)
5 插入点的父亲为红,父亲的兄弟节点为红,插入点在内侧(两次旋转)
6 插入点的父亲为黑,直接插入
*//
//这里判断父节点是否为祖先节点的左节点和 取得伯父节点,判断伯父节点的颜色的目的是为了识别以上者6种情况
if(y && y->color == __rb_tree_red)
//不需要旋转,直接调整颜色,但是要调整到祖父的颜色,所以要再检查祖父的颜色是否达到要求,
{
clip_image026
x->parent->color = __rb_tree_black;
y->color = __rb_tree_black;
x->parent->parent->color = __rb_tree_ted;
x = x->parent->parent; //让祖父节点再被考察一次
}
Else // 没有伯父节点或者伯父节点为黑
{ If(x == x->parent->right) //如果新节点为父节点的右子节点,也就是在内侧,满足第2种情况 {
clip_image028
X = x->parent;
__rb_tree_rotate_left(x, root); //进行左旋
} clip_image030//左旋后到达这个图形,满足第1种情况,然后做下面的处理,做右旋 x->parent->color = __rb_tree_black; x->parent->parent->color = __rb_tree_red; __rb_tree_rotate_right(x->parent->parent, root); clip_image032 //最后形成这样 }
}
Else //父节点是右子节点
{ __rb_tree_node_base* y = x->parent->parent->left; If(y&& y->color == rb_tree_red) {
clip_image034
//简单修改颜色就可以
x->parent->color = __rb_tree_black;
y->color = __rb_tree_black;
y->color = __rb_tree_black;
x->parent -> parent ->color = __rb_tree_red;
x = x->parent->parent;
} Else { If(x == x->parent->left) //先判断是否要进行叶子上的旋转 {
clip_image036
X = x->parent;
__rb_tree_rotate_right(x, root);
} clip_image038 x->parent->color = __rb_tree_black; x->parent->parent->color = __rb_tree_red; __rb_tree_rotate_left(x->parent->parent, root); } }
}
Root->clolor = _rb_tree_black;
}

__rb_tree_rebalance的更多相关文章

  1. 带你深入理解STL之RBTree

    最近一直忙于校招的笔试,STL的深入理解系列也耽搁了好几天,再加上!红黑树真的是超级超级难理解,超级超级复杂,参考了好多博客上的大神的理解才稍微明白一点,勉强入个门,下面请以一个菜鸟的角度跟着我一起学 ...

  2. stl源码剖析 详细学习笔记 RB_tree (2)

    //---------------------------15/03/22---------------------------- //一直好奇KeyOfValue是什么,查了下就是一个和仿函数差不多 ...

  3. STL标准库-容器-rb_tree

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 红黑树,关联式容器底层实现(map set),在使用中基本运用不到,但是还是想了解一下他的运作方式 Red_Black tree ...

  4. stl_tree.h

    stl_tree.h G++ ,cygnus\cygwin-b20\include\g++\stl_tree.h 完整列表 /* * * Copyright (c) 1996,1997 * Silic ...

  5. SGI RB-tree深入理解

    前言 在学习STL源码之前我也曾无数次想要弄懂红黑数的原理,奈何每次都被困难打退.说实话,红黑树是真的很难理解,需要不断沉淀才能慢慢体会其妙处.这两天看SGI的RB-tree实现,结合侯捷老师的< ...

随机推荐

  1. flask - 1

    from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return 'Hello, Worl ...

  2. [转]Hexo博客添加访问统计 - 记录

    引入不蒜子 <script async src="//dn-lbstatics.qbox.me/busuanzi/2.3/busuanzi.pure.mini.js"> ...

  3. 文本太长,用省略号显示的css样式

    ——html代码 <divid="d1" title="鼠标放上显示的文字"></div> ——css代码 #d1{ width:300 ...

  4. [LeetCode] 70. Climbing Stairs(斐波那契数列)

    [思路] a.因为两种跳法,1阶或者2阶,那么假定第一次跳的是一阶,那么剩下的是n-1个台阶,跳法是f(n-1); b.假定第一次跳的是2阶,那么剩下的是n-2个台阶,跳法是f(n-2) c.由a.b ...

  5. 利用 spring 的 task:scheduled-tasks 执行定期任务

    ref是工作类 method是工作类中要执行的方法 initial-delay是任务第一次被调用前的延时,单位毫秒 fixed-delay是上一个调用完成后再次调用的延时 fixed-rate是上一个 ...

  6. SRM710 div1 MagicNim(博弈论)

    题目大意: 给出n+1堆石子,前n堆石子的数量是a[i],最后一堆只有1个石子,但是具有魔力 拿走该石子的一方可以选择接下来是进行普通的Nim游戏还是anti-nim游戏 问是先手必胜还是必败 首先拿 ...

  7. 【题解】HNOI2018寻宝游戏

    太厉害啦……感觉看到了正解之后整个人都惊呆了一样.真的很强%%% 首先要注意到一个性质.位运算列与列之间是不会相互影响的,那么我们先观察使一列满足条件的操作序列需要满足什么条件.&0时,不论之 ...

  8. day10_plus

    刚才发奖哈哈哈 想不到被惨虐的我还能混个牌子哈哈哈好开心

  9. There is an overlap in the region chain

    ERROR: (regions day_hotstatic,860010-2355010000_20140417_12_entry_00000000321,1398674475358.0dc20573 ...

  10. Java之戳中痛点 - (5)switch语句break不能忘以及default不同位置的用法

    先看一段代码: public class Test{ public static void main(String[] args){ System.)); } } public static Stri ...