红黑树不追求"完全平衡",即不像AVL那样要求节点的 |balFact| <= 1,它只要求部分达到平衡,但是提出了为节点增加颜色,红黑是用非严格的平衡来换取增删节点时候旋转次数的降低,任何不平衡都会在三次旋转之内解决,而AVL是严格平衡树,因此在增加或者删除节点的时候,根据不同情况,旋转的次数比红黑树要多。
就插入节点导致树失衡的情况,AVL和RB-Tree都是最多两次树旋转来实现复衡rebalance,旋转的量级是O(1)
删除节点导致失衡,AVL需要维护从被删除节点到根节点root这条路径上所有节点的平衡,旋转的量级为O(logN),而RB-Tree最多只需要旋转3次实现复衡,只需O(1),所以说RB-Tree删除节点的rebalance的效率更高,开销更小!
AVL的结构相较于RB-Tree更为平衡,插入和删除引起失衡,如2所述,RB-Tree复衡效率更高;当然,由于AVL高度平衡,因此AVL的Search效率更高啦。
针对插入和删除节点导致失衡后的rebalance操作,红黑树能够提供一个比较"便宜"的解决方案,降低开销,是对search,insert ,以及delete效率的折衷,总体来说,RB-Tree的统计性能高于AVL.
故引入RB-Tree是功能、性能、空间开销的折中结果。
5.1 AVL更平衡,结构上更加直观,时间效能针对读取而言更高;维护稍慢,空间开销较大。
5.2 红黑树,读取略逊于AVL,维护强于AVL,空间开销与AVL类似,内容极多时略优于AVL,维护优于AVL。
基本上主要的几种平衡树看来,红黑树有着良好的稳定性和完整的功能,性能表现也很不错,综合实力强,在诸如STL的场景中需要稳定表现。
红黑树的查询性能略微逊色于AVL树,因为其比AVL树会稍微不平衡最多一层,也就是说红黑树的查询性能只比相同内容的AVL树最多多一次比较,但是,红黑树在插入和删除上优于AVL树,AVL树每次插入删除会进行大量的平衡度计算,而红黑树为了维持红黑性质所做的红黑变换和旋转的开销,相较于AVL树为了维持平衡的开销要小得多

总结:实际应用中,若搜索的次数远远大于插入和删除,那么选择AVL,如果搜索,插入删除次数几乎差不多,应该选择RB。

HashMap为什么使用红黑树相关推荐

  1. HashMap为什么用红黑树而不用跳表?redis的zset为什么用跳表而不用红黑树?

    问题引入 前些天在思考zset为什么用跳表而不用红黑树时,自然想到了HashMap为什么用红黑树而不用跳表,做了一些查询和考虑,以此记录结果 redis的zset为什么用跳表而不用红黑树? 1.跳表的 ...

  2. 遍历HashMap源码——红黑树原理、HashMap红黑树实现与反树型化(三)

    本章将是HashMap源码的最后一章,将介绍红黑树及其实现,HashMap的remove方法与反树型化.长文预警~~ 遍历HashMap源码--红黑树原理.HashMap红黑树实现与反树型化 什么是红 ...

  3. [Java 8 HashMap 详解系列]7.HashMap 中的红黑树原理

    [Java 8 HashMap 详解系列] 文章目录 1.HashMap 的存储数据结构 2.HashMap 中 Key 的 index 是怎样计算的? 3.HashMap 的 put() 方法执行原 ...

  4. HashMap中的红黑树

    转载自:http://blog.csdn.net/u011240877/article/details/53358305 张拭心 读完本文你将了解到: 点击查看 Java 集合框架深入理解 系列 - ...

  5. hashmap为什么用红黑树_关于HashMap的实现,一篇文章带你彻底搞懂,再也不用担心被欺负

    推荐学习 刷透近200道数据结构与算法,成功加冕"题王",挤进梦中的字节 面试官杠上Spring是种什么体验?莫慌,送你一套面试/大纲/源码 前言 在介绍HashMap之前先了解一 ...

  6. hashmap为什么用红黑树_全网最全,面试常问的HashMap知识点

    引言 其实我很早以前就想写一篇关于HashMap的面试专题.对于JAVA求职者来说,HashMap可谓是集合类的重中之重,甚至你在复习的时候,其他集合类都不用看,专攻HashMap即可. 然而,鉴于网 ...

  7. hashmap为什么用红黑树_要看HashMap源码,先来看看它的设计思想

    HashMap 是日常开发中,用的最多的集合类之一,也是面试中经常被问到的 Java 类之一.同时,HashMap 在实现方式上面又有十分典型的范例.不管是从哪一方面来看,学习 HashMap 都可以 ...

  8. HashMap 数据结构之红黑树, 红黑树在什么时候左旋 右旋 如何旋转

    树结构是数据结构中最经典最常用的结构之一,也是面试中常问的面试题,最近学习了一下红黑树的知识,记录整理一下 文章目录 一.红黑树的特征 二.变色左旋和右旋 1.变色规则 2.左旋 3.右旋 总结 前言 ...

  9. 花开--HashMap系列之红黑树篇(二)

    昨天小宋把HashMap的基本理论和1.7底层做了着重的分析讲解,今天小宋接着上篇文章最后提到过的红黑树继续往下讲. 文章目录 红黑树 二叉查找树简介 左旋和右旋(平衡二叉查找树) 红黑树简介 红黑树 ...

  10. hashmap中用红黑树不用其他树_为什么hashMap引入了红黑树而不是其他结构

    1.为什么hashMap使用红黑树而不是其他结构? 在回答这个问题之前,我们先了解一下有关二叉树的基本内容. ①二叉排序树(又称二叉查找树): 1)若左子树不为空,则左子树上所有结点的值均小于根结点的 ...

最新文章

  1. SLAM架构的两篇顶会论文解析
  2. 计算机视觉编程——多视图几何
  3. 青岛理工邀请赛(难受的一次经历)之显示屏(按着倍数放大数字)
  4. QI实例-改变空间参考
  5. 生活质量衡量系统_一文看懂质量管理精髓——“零缺陷”管理
  6. RGB vs YCbCr(YUV)
  7. linux jdk路径
  8. Servlet文件下载
  9. codeproject
  10. 数字与静态(HeadfirstJava随笔)(转)
  11. 中国电信路由器设置虚拟服务器,中国电信天翼宽带无线路由器设置方法
  12. 数据库多表查询关联查询SQL语句
  13. 两级运放积分器的带宽分析
  14. 【VS开发】ClientToScreen 和ScreenToClient 用法
  15. JTree创建、获取和删除节点的方法
  16. PostgreSQL数据库统计信息——analyze大致流程
  17. 六款国产杀毒软件资源占用测试,八款杀毒软件横向评测:系统资源占用篇
  18. 双硬盘双win10互不干扰_双硬盘双系统 完全独立|硬盘安装Win10单双系统的详细步骤...
  19. Faster R-CNN最全讲解
  20. 六大维度全景呈现:《数据安全法》实施一周年行业洞察

热门文章

  1. 【Python】实例属性不能通过类访问,案例演示
  2. Hadoop 3的主要优缺点
  3. NETGEAR WNR2200 路由器 变身打印服务器
  4. 单元测试 php,PHP单元测试PHPUnit简单用法示例
  5. 残差网络resnet详解
  6. 使用自己的数据训练MobileNet SSD v2目标检测--TensorFlow object detection
  7. 程序员婚恋铁律:男人三不娶,护士幼师银行女,欢迎留言讨论
  8. 《Win7设备驱动程序开发》学习笔记
  9. 群晖DS218+做maven私服(nexus3)
  10. 网络工程师 B站希赛视频第7章局域网技术学习笔记