哈希映射适用于X个元素

Hashmap suited for X number of elements?

本文关键字:元素 适用于 映射 哈希      更新时间:2023-10-16

哈希映射适用于多大范围的元素?

我知道一切都是恒定的时间,唯一造成的问题是大量的内存消耗,但我很想知道在多大程度上太多了?

任何数字范围。

唯一的问题当然不是内存消耗。内存消耗通常在元素数量上是线性的,这并不是特别糟糕。

如果存在大量哈希冲突(元素哈希为相同值),这将是一个主要问题,因为您必须搜索具有该哈希值的所有元素才能找到正确的哈希值。存储具有相同哈希值的元素的一种流行方法(称为"单独链接")是使用链表,并且在链表中搜索很慢。

哈希表的性能是否良好取决于:

  • 散列元素的分布(这将影响散列冲突的数量),这取决于实际元素和散列函数
  • 哈希表的负载因子(哈希表中有多少元素与其大小相关)。如果这个值太高,即使有一个不错的分布,也会有大量的哈希冲突