数组,链表,哈希表的区别 [Java][数据结构]

数组,链表,哈希表的区别

  1. 数组 : 连续的一片连续的存储空间 , 占用内存严重 , 故空间复杂度高, 寻址容易 ,但是插入和删除困难

  2. 链表 : 存储空间松散 , 占用内存宽松 , 通过指针关联前后位置元素, 所以空间复杂度小 , 寻址困难 , 但是插入和删除比较快

  3. 哈希表 : 结合了数组和链表 , 结合了数组和链表两者的特点

    • 元素存储到哈希表底层数组中的位置: index = key.hash() & (len - 1)

HashMap是一个线性数组 , 内部由Entry对象组成 , 每一个Entry对象包括了: key(键 — > 也称之为关键码值) , value(值 --> 真正的数据) , hashCode(hash码值) , next(指针域 --> 指向下一个元素)

  • 注意: HashMap中可以存储null值, key为null值的元素放在数组下标为0的位置对应的链表中

解决Hash冲突的四种方法:

  1. 开放定址法:

开放定址法就是一旦发生了冲突之后就去寻找下一个空的散列地址, 只要散列表足够的, 空的散列地址总能找到, 找到之后就将其录入, 容易发生聚集

  1. 再Hash(哈希)法

再哈希法又叫做双哈希法 , 有多个不同的Hash函数, 当发生了hash冲突的时候, 使用第二个,第三个 …等哈希函数, 计算地址, 直到无冲突,不容易发生聚集,但是增加了计算的时间

  1. 链地址法

每个哈希表结点都有一个next指针, 多个哈希表结点的位置冲突时就将冲突的多个节点合在一起构成一个单向链表 , 被分配到同一个索引上的多个节点可以使用这个单向链表连接起来

  • HashMap就是使用这种方式解决hash冲突的
  1. 建立公共溢出区

将哈希表分为基本表和溢出表两部分,但凡是和基本表发生了冲突的元素我们都填入到溢出表中

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值