数据结构之红黑树

红黑树

二叉查找树:

1.子树上所有结点的值均小于或等于它的根结点的值。

2.子树上所有结点的值均大于或等于它的根结点的值。

3.左、右子树也分别为二叉排序树。

img
红黑树是一种自平衡的二叉查找树,要符合五种规则

1.结点是红色或黑色。

2.根结点是黑色。

3.每个叶子结点都是黑色的空结点(NIL结点)。

4 每个红色结点的两个子结点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色结点)

5.从任一结点到其每个叶子的所有路径都包含相同数目的黑色结点。

img

红黑树自平衡调整的方法有变色和 左右旋转

变色

img

左旋转

img

右旋转

img
红黑树的插入:
插入分为五种特定的局面 下面例子并非整个红黑树

**局面1:**新结点(A)位于树根,没有父结点。

img

然后变色

img

局面2:新结点(B)的父结点是黑色。

img

局面3:新结点(D)的父结点和叔叔结点都是红色。

img

这样一来,结点B所在路径凭空多了一个黑色结点,打破了规则5。因此我们让结点A变为红色:

img

这时候,结点A和C又成为了连续的红色结点,我们再让结点C变为黑色 就符合规则了。

img

(注:这个并非是整个红黑树,而是子树,如果是整个红黑树的话,应该是先右旋转,头节点为B红,右孩子为黑A。左孩子为D红,C红为黑A的右孩子,然后节点B 和节点D变黑 ,局面4 应该也是直接把B节点变成黑色节点)

局面4:新结点(D)的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的右孩子,父结点(B)是祖父结点的左孩子。

img

我们以结点B为轴,做一次左旋转,使得新结点D成为父结点,原来的父结点B成为D的左孩子:

img

进入局面五 新结点(D)的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的左孩子,父结点(B)是祖父结点的左孩子。

我们以结点A为轴,做一次右旋转,使得结点B成为祖父结点,结点A成为结点B的右孩子:

img

接下来,我们让结点B变为黑色,结点A变为红色:

img

整颗红黑树插入步骤 新节点是21 现在属于上面的局面3

img

将22 27 变成黑节点, 25变成红节点,现在属于上面的局面5

img

于是我们以根结点13为轴进行左旋转,使得结点17成为了新的根结点:

img

接下来,让结点17变为黑色,结点13变为红色 就符合规则了。

img

红黑树删除

先介绍下BST的删除流程;

1 待删除节点如果是叶子节点直接删除

2 待删除节点有一个孩子直接让孩子节点代替

3 待删除节点有两个孩子让最接近待删除的值替代待删除结点,然后删除 替代节点,但习惯上我们选择仅大于待删除结点的结点

第一步 如果待删除结点有两个非空的孩子结点,转化成待删除结点只有一个孩子(或没有孩子)的情况。

删除节点8,找最接近的值进行代替,然后删除节点10

img img

根据待删除结点和其唯一子结点的颜色,分情况处理。

情况1,自身是红色,子结点是黑色: 直接删除

img img

情况2,自身是黑色,子结点是红色:直接删除节点然后红变黑

img img

情况3,自身是黑色,子结点也是黑色,或者子结点是空叶子结点:直接删除,可能会造成一条路径上的黑色节点变少,这时候我们进入第三步,专门解决父子双黑的情况。

img

第三步:遇到双黑结点,在子结点顶替父结点之后,分成6种子情况处理。

子情况1,结点2是红黑树的根结点:此时所有路径都减少了一个黑色结点,不需要调整。

img

子情况2,结点2的父亲、兄弟、侄子结点都是黑色:把兄弟节点变成红色 (注:如果A是整个红黑树的某个子树 就让A扮演2的角色依次递归,直至符合规则)

img img

子情况3,结点2的兄弟结点是红色: 旋转然后B变黑 A 变红 (这样的意义是什么呢?结点2所在的路径仍然少一个黑色结点)

img img

子情况4,结点2的父结点是红色,兄弟和侄子结点是黑色:A变成黑色,B 变成红色,每条路径的黑色节点就相同了

imgimg

子情况5,结点2的父结点随意,兄弟结点B是黑色右孩子,左侄子结点是红色,右侄子结点是黑色:

这种情况下,首先以结点2的兄弟结点B为轴进行右旋,接下来结点B变为红色,结点C变为黑色。

img img

子情况6,结点2的父结点随意,兄弟结点B是黑色右孩子,右侄子结点是红色:首先以结点2的父结点A为轴左旋,接下来让结点A和结点B的颜色交换,并且结点D变为黑色:

imgimgimg

经过结点2的路径由(随意+黑)变成了(随意+黑+黑),补充了一个黑色结点;

经过结点D的路径由(随意+黑+红)变成了(随意+黑),黑色结点并没有减少。

对应平衡二叉树 左右子树高度不超过1,查询效率更高,但是更容易平衡调整,消耗资源

红黑树来说 左右子树相差不超过2倍,插入比平衡二叉树效率更高。

转自:漫画:什么是红黑树?(整合版)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
红黑树是一种自平衡的二叉查找树,它在插入和删除节点时能够保持树的平衡。红黑树的概念可以参考。在Java中实现红黑树,可以按照以下步骤进行: 1. 首先将红黑树当作一颗二叉查找树,将新节点插入到适当的位置上。 2. 将插入的节点着色为"红色"。 3. 红黑树的特性,通过一系列的旋转和着色等操作,使树重新保持红黑树的性质。 具体的插入过程可以参考中提供的代码。在代码中,使用了旋转、旋转和颜色翻转等操作来重新平衡红黑树。 首先,如果节点子树是红色而子树是黑色,可以通过旋转操作将其变为子树为红色,子树为黑色的情况。 其次,如果节点子树子树子树都是红色,可以通过旋转操作将其修正为上述情况。 最后,如果节点子树子树都是红色,可以通过颜色翻转操作将其修正为子树子树都为黑色的情况。 在插入完节点后,需要将节点的颜色设置为黑色,以确保红黑树的性质满足。 这样,通过以上的步骤,就能够实现对红黑树的插入操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Java数据结构红黑树的真正理解](https://download.csdn.net/download/weixin_38622475/12770272)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Java高阶数据结构红黑树](https://blog.csdn.net/qq15035899256/article/details/126678970)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Java数据结构——红黑树](https://blog.csdn.net/weixin_30699463/article/details/95256212)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值