经典搜索算法之2-3-4树与红黑树

1.2-3-4树

    在笔者上篇文章中,介绍了B树和B+树,这里我所说的2-3-4树就是阶为4的B树。根据离散数学的图论相关知识,可以证明2-3-4树和红黑树是等价的。对于m阶(m指的结点的最大分支数)B树,其结点的值的个数n:1<=n<m。因此,对于2-3-4树,其结点的值的个数1<=n<4,如下图所示:

                      

2.红黑树

    红黑树也是一种平衡查找树,只不过其结点是带有色彩的二叉查找树,红黑树可以保证在Olog(n)时间内完成查找,插入和删除。此外,红黑树具有其下特性:

  1. 结点是红色或黑色。
  2. 根结点是黑色。
  3. 每个叶子结点都带有两个空的黑色结点(称之为NIL节点,它又被称为黑哨兵)。
  4. 每个红色结点必须有两个黑色的子结点。(从每个叶子到根的所有路径上不能有两个连续的红色结点。)
  5. 从任一结点到其每个叶子结点的所有简单路径都包含相同数目的黑色节点。

  下面进行举例说明:

                               

    上图中左右两棵树是一样的,只不过一个画出了null结点,一个没有画出。我们在理解和真正操作的时候,以没有null结点的图进行理解操作即可。添加null结点表示数据结束,保证了所有结点都有两个子结点,这样做的好处是使得红黑树在算法的实现上更简单些。

   下面我们从图来看2-3-4树和红黑树为何的等价的:

   首先,我们将上图中的红结点放平:

                                      

    然后,我们将红结点合并到与其在同一层、并直接相连的黑结点:

                                                          

   通过上面过程可看出任何红黑树可以转化为2-3-4树。都可以可以想想如何将最上面的2-3-4树转化为红黑树。

   红黑树的旋转变色:

   由于插入操作可能会破坏红黑树的平衡性,因此我们在插入值后需要对红黑树进行调整,这个调整过程就是红黑树结点的颜色变换和旋转操作,这些操作都可以从2-3-4树的角度来理解。

   假设我们在上图的2-3-4树中插入17,则:

         

    将其转化为红黑树:

      

    插入完毕,相比直接在原红黑树进行旋转变色,以2-3-4树的方式更容易简单理解。插入17后的红黑树其实是在原红黑树基础上旋转、变色得到的。

    红黑树一般应用在关联数组,关联数组是一种具有特殊索引方式的数组。不仅可以通过整数来索引它,还可以使用字符串或者其他类型的值来索引它。通俗的讲,关联数组就是大家熟知的key-value系统。最典型的是,在java8以前,hashmap是数组和链表实现的,在java8以后,为了防止某一索引处链表过长,造成hashmap的查询、增删操作效率降低,在某一索引处的链表长度达到8时,该处的链表会被红黑树所替换,以保证hashmap的效率。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

超级战斗王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值