V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Powered
V2EX  ›  Java

HashTable 的 Java 实现

  •  
  •   Powered · 2016-10-25 00:15:33 +08:00 · 1896 次点击
    这是一个创建于 2957 天前的主题,其中的信息可能已经有所发展或是发生改变。
    http://www.cnblogs.com/goodwin/p/4102702.html

    HashTable在java中

    计算hash(key)得到index索引

    那么是把value放在一个数组中,index作索引

    还是把key-value对放在对应的bucket中?
    4 条回复    2016-10-25 09:51:08 +08:00
    SoloCompany
        1
    SoloCompany  
       2016-10-25 01:09:08 +08:00
    不管是什么实现 Bucket 当然需要存 key pair 了
    否则,先不谈遍历,你 put 的时候怎么知道是否发生了 collision
    Powered
        2
    Powered  
    OP
       2016-10-25 01:15:08 +08:00 via Android
    @SoloCompany
    所以是, bucket 中存 entry 对象, hash(key)得到的 index 是 bucket 的索引吗
    SoloCompany
        3
    SoloCompany  
       2016-10-25 01:20:20 +08:00
    @Powered bucket 可以放一个链表,或者数组,因为你不能忽略 collision
    cloud107202
        4
    cloud107202  
       2016-10-25 09:51:08 +08:00
    一般 bucket 中是个 entry 链表, hash(key1)得到 bucket 的 index ,然后遍历链表,比对 key1 与链表每个 entry 对象的 key 。如果 hash 函数设计良好,元素均匀的分散在各个 bucket 中, entry 链表的遍历开销可认为是 O(1)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2816 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 14:31 · PVG 22:31 · LAX 06:31 · JFK 09:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.