为什么HashMap使用红黑树而不使用AVL树?

红黑树适用于大量插入和删除;因为它是非严格的平衡树;只要从根节点到叶子节点的最长路径不超过最短路径的2倍,就不用进行平衡调节

AVL 树是严格的平衡树,上述的最短路径与最长路径的差不能超过 1,AVL 允许的差值小;在进行大量插入和删除操作时,会频繁地进行平衡调整,严重降低效率;

红黑树虽然不是严格的平衡树,但是其依旧是平衡树;查找效率是 O(logn)

AVL也是 O(logn)

红黑树舍去了严格的平衡,使其插入,删除,查找的效率稳定在 O(logn)

反观 AVL 树,查找没问题 O(logn),但是为了保证高度平衡,动态插入和删除的代价也随之增加,综合效率肯定达不到 O(logn)

所以在进行大量插入,删除操作时,红黑树更优一些

HashMap 用到数据结构有(JDK 1.8):数组,链表,红黑树

在没有地址冲突时,效率 O(1)

有少量地址冲突,在冲突的地址拉链(建链表),效率在 O(1) ~ O(logn) 之间

有大量地址冲突,在冲突的地址建红黑树,效率 O(logn)

最新文章

  1. otter双主同步安装与配置
  2. 轻松自动化---selenium-webdriver(python) (十)
  3. mysql处理字符串
  4. INNO setup安装卸载钱判断进程中是否在运行总结
  5. 怎么运用ZBrush中的Z球制作身体部分
  6. 我装GitHub的过程
  7. HDU 1272 小希的迷宫(并查集)
  8. JBPM4入门——9.自动节点单线执行
  9. 使用FTP搭建YUM
  10. DBA
  11. 防止SQL注入攻击,数据库操作类
  12. C语言初学 if-else语句判断俩数的最大值
  13. Opencv 函数
  14. mma ctf 1st && csaw 2015
  15. Vijos P1680距离
  16. COC建筑拖动的实现
  17. 如何在HTTP头中隐藏PHP版本号
  18. Java核心技术卷一基础知识-第8章-事件处理-读书笔记
  19. VUE 浏览器关闭时清空localStorage
  20. spring 测试类test测试方法

热门文章

  1. 题解 CF17E 【Palisection】
  2. 采用 DIV+CSS 布局网页练习
  3. Gin 08 上传文件
  4. dotnet 委托的实现解析
  5. Three.js 火焰效果实现艾尔登法环动态logo 🔥
  6. k8s 开船记-脚踏两只船:船儿还是旧的好,不翻船才是硬道理
  7. loj2985「WC2019」I 君的商店(二分,思维)
  8. JavaScript 事件循环(1) —— 从 setTimeout 说起
  9. JDBC 中文编码
  10. Mybatis框架基础入门(三)--Mapper动态代理方式开发