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

两者平均查找效率,为何会选择红黑树呢?... 两者平均查找效率,为何会选择红黑树呢? 展开
 我来答
小黑哎啊
科技发烧友

2021-07-10 · 智能家居/数码/手机/智能家电产品都懂点
知道大有可为答主
回答量:1642
采纳率:74%
帮助的人:362万
展开全部
红黑树适用于大量插入和删除;因为它是非严格的平衡树;只要从根节点到叶子节点的最长路径不超过最短路径的2倍,就不进行平衡调节
AVL树是严格的平衡树,上述的最短路径与最长路径的差不能超过|1|,AVL允许的差值小;在进行大量插入和删除操作时,频繁地进行平衡调整会严重降低效率;
红黑树虽然不是严格的平衡树,但是其依旧是平衡树;查找效率是logn;
AVL也是logn;
红黑树舍去了严格的平衡,使其插入,删除,查找的效率稳定在O(logn)
反观AVL树,查找没问题O(logn),但是为了保证高度平衡,动态插入和删除的代价也随之增加,综合效率肯定达不到O(logn)
所以在进行大量插入,删除操作时,红黑树更优一些
Hashmap用到数据结构有
数组,链表,红黑树
在没有地址冲突时,效率O(1)
有少量地址冲突,在冲突的地址拉链(建链表),效率在O(1)~O(logn)之间
有大量地址冲突,在冲突的地址建红黑树,效率O(logn)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式