红黑树

作者: 做自己的Yang光 | 来源:发表于2019-04-08 14:11 被阅读0次

红黑树的特性?应用?优势?什么情况下变色?什么情况下旋转?

https://juejin.im/post/5a27c6946fb9a04509096248#comment

红黑树是一种自平衡的二叉查找树。除了符合二叉查找树的基本特性外,还具备以下特性

1.节点是红色或黑色。

2.根节点是黑色。

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

4.每个红色节点的两个子节点都是黑色,反之不一定。(从每个叶子到根的所有路径上不能有两个连续的红色节点)

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

因这些规则限制,才保证了红黑树的自平衡。红黑树从根到叶子的最长路径不会超过最短路径的2倍。

红黑树的应用?

集合类TreeSet、TreeMap以及JDK1.8之后的HashMap底层都用到了红黑树。

为什么要用红黑树?/ 优势?

解决二叉查找树的缺陷,因二叉查找树多次插入新节点导致不平衡,退化成一个线性结构。

相关文章

  • 数据结构—树—红黑树

    红黑树概述 红黑树的插入 红黑树的删除

  • TreeMap

    需要先了解红黑树,这是之前分析红黑树的文章。之前在分析红黑树时,我认为红黑树=二叉查找树+红黑平衡,关于二叉查找树...

  • 数据结构与算法-AVL 红黑树

    AVL树AVL树 算法红黑树红黑树 B站

  • [转载]红黑树

    https://zhuanlan.zhihu.com/p/24367771红黑树简介红黑树插入红黑树删除

  • 拿下红黑树

    红黑树 红黑树、2-3树的简单定义: 实现红黑树的基本结构以及添加操作(维护定义,左旋、右旋、颜色反转) 红黑树与...

  • 红黑树

    啥是红黑树,红黑树 = 二叉树

  • 彻底理解红黑树(二)之 插入

    彻底理解红黑树(一)之 二叉搜索树彻底理解红黑树(二)之 插入彻底理解红黑树(三)之 删除 前言 红黑树的插入情况...

  • 彻底理解红黑树(三)之 删除

    彻底理解红黑树(一)之 二叉搜索树彻底理解红黑树(二)之 插入彻底理解红黑树(三)之 删除 前言 红黑树的删除情况...

  • Golang红黑树

    红黑树 红黑树是每个节点都带有颜色属性(红色或黑色)的二叉查找树。红黑树也属于自平衡二叉查找树。 红黑树具有如下性...

  • 数据结构红黑树添加、修改原理分析

    源码分析大纲 数据结构解析 红黑树试下原理刨析 数据结构解析 1.红黑树 1.1 红黑树概念 红黑树(Red Bl...

网友评论

      本文标题:红黑树

      本文链接:https://www.haomeiwen.com/subject/cvvuiqtx.html