平衡二叉搜索树(AVL)和红黑树(RB-Tree)

二、红黑树——一种常被使用的平衡二叉搜索树

1、四大性质
  • 1、每个节点都有颜色,要么黑色,要么是红色。
    2、树的根节点必须是黑色。
    3、父子两节点不得同时为红色。
    4、任一节点到叶子节点的每条路径上的黑色节点个数必须相同。
2、由四大性质引出的要插入的节点性质讨论
  • 由二叉搜索树的性质可知,插入的节点一定是作为叶子节点。
  • 可将当前叶子节点的下一NULL节点看做黑色。
  • 由性质4可知,插入的叶子节点的颜色一定是红色。
    否则为黑色,该路径黑色节点+1,会破坏原红黑树的各条路径的黑色节点总个数相同原则。
  • 由上可知插入节点必为红色,然后结合性质3可知,若其父节点为黑色,则没问题可以直接插入。
    但是,若其父节点为红色,则必然引起【父子节点同时为红色】的冲突。此时就要旋转节点和给节点变色,直到满足红黑树的四大性质。
3、红黑颜色的本质是bool值,红色是false0,黑色是true1
image.png
4、红黑树增加一个特殊的header节点

初始时,herder的左右子节点都指向本身,插入节点后;左子节点作为begin()指向的是(most)left最左边也就是最小值;右子节点作为end()指向的是(most)right最右边也就是最大值。


image.png
5、迭代器++和--的特殊操作
  • 双向单步迭代器类型,和list一样,也是不能跳步随机访问的。
  • ++和--跳到的元素,实际上是按照二叉搜索树的中序遍历排序结果来移动。
    ++就是移动到排序序列中的下一个元素位置,实际上指针再树中的移动情况可能更麻烦。
    --就是移动到排序序列中的上一个元素位置。
  • 比较特殊的header和root,若是root没有右子节点(或左子节点),那么root++(或--)就到了header。因为root和header互为parent父节点。

6、AVL-tree平衡二叉树的平衡破坏情况

每个结点有一个元素是平衡因子Balance Factor,BF=该结点左子树高度-右子树高度,当BF的绝对值大于1时说明平衡被破坏。距离插入结点最近的BF绝对值大于1的结点,就作为要开始接受调整的结点,以它为根的子树叫做最小不平衡子树


AVL-tree平衡调整

6.1、红黑树新插入节点保持平衡的变色和旋转条件

  • 新插入节点X(红色)的父节点若是黑色,则直接插入,无冲突。(如根节点默认黑色,则刚开始的左右子节点都无冲突插入)
  • 新插入节点X(红色)的父节点也是红色,那么一定有冲突。要么只进行变色,要么旋转(旋转一定附带变色)。【下面讨论的一定是这种父节点为红色有冲突的情况】
  • 【X的父节点有兄弟,即X有伯父】

不管是左左(父节点是祖父节点的左子节点,X节点又是父节点的左子节点,后面同理)、左右、右左、右右,全部都只需要变色处理,而不需要旋转。
为了满足性质3【父子节点不能双红】则需要将父节点和伯父节点都转为黑色。此时这两路径黑色节点数+1,为了满足性质4【各节点所有路径黑色节点数相同】则需要将祖父节点变为红色。然后还需要继续向上检查是否有父子双红的颜色冲突,有的话就还需要继续向上变色处理,可能直到根节点才结束。

  • 【X的父节点无兄弟,即X无伯父】

1、左左,单右旋转,附带变色。
2、右右,单左旋转,附带变色。
3、左右,先单左再单右的双旋转,附带变色。
4、右左,先单右再单左的双旋转,附带变色。

7、关于单旋转,双旋转的细节

单左旋。对应右右,或者左右的第一次旋转


单左旋

单右旋。对应左左,或者右左的第一次旋转


单右旋

8、平衡调整函数,调整颜色、调整位置(调用左旋转和右旋转)

调整平衡树函数

一个图示实例:将序列10、7、8、15、5、6、11、13、12依次插入红黑树的调整过程》》》》》


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容