• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

解决Hash冲突的两种策略

武飞扬头像
L--K
帮助1

什么是Hash冲突?

学新通 

由于HashMap是数组 链表的方式存储数据,内部封装了一个Entry数组,数组里面的每个单元又是一个链表。即是数组就会有长度。对于数组来说往里面放数据就是占据数组下标对应的空间。

然而往hashMap中存放数据并不是直接放进去的,而是先通过hash计算数组下标,最后根据计算出来的下标位置将数据存放到数组里。hash值是有可能重复的,这样使用相同的下标就会出现冲突。

解决冲突的两种方式:

1.开放地址法

2.链地址法

两者的区别:

1.开放地址法:容易产生堆积问题;插入时可能会出现多次冲突的现象,不能直接删除元素,只能做懒惰删除;当装填因子过大时,性能急剧下降。

2.链地址法:处理冲突简单,且无聚集现象,平均查找长度短;链表中的结点是动态申请的,适合构造表不能确定长度的情况。插入结点应该在链首,删除结点比较方便,只需调整指针而不需要对其他冲突元素作调整。

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgfjbej
系列文章
更多 icon
同类精品
更多 icon
继续加载