【问题标题】:Time complexity of hash table and arraylist哈希表和arraylist的时间复杂度
【发布时间】:2014-09-13 19:51:50
【问题描述】:

为什么haskey的时间复杂度是O(1)。为了找到一个键,它必须迭代列表中的所有元素,所以为什么它是 O(1)
containsarraylist 方法的时间复杂度是多少

【问题讨论】:

  • 何不试试谷歌搜索!
  • 没有得到满意的答复
  • 你确定哈希总是 O(1) 吗?碰撞呢?
  • ya @zerocool 同意你可以给我一些链接或信息

标签: java


【解决方案1】:

哈希表不是列表。它是专门为普通情况下的 O(1) 查找设计的数据结构(worst-case 查找确实是 O(n))。它通过 hash 的概念来实现这一点,它是从键的内容派生的数字,用于直接计算键在数组中的索引。

ArrayList 只是下面的一个数组,所以contains 是您对线性搜索结构的期望。

【讨论】:

    猜你喜欢
    • 2020-11-19
    • 2011-04-26
    • 1970-01-01
    • 2013-03-14
    • 2016-11-03
    • 2019-05-10
    • 1970-01-01
    • 2019-10-09
    • 2018-09-14
    相关资源
    最近更新 更多