浅谈哈希表存储效率一般不超过50%的原因
投稿:jingxian
下面小编就为大家带来一篇浅谈哈希表存储效率一般不超过50%的原因。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
本文主要是讲"哈希表的存储效率一般不超过50%"的原因。
Hash Table 常用于频繁进行 key/value 模式的查找中。(查找模式,如匹配查找)
哈希表最大的优点在于查找速度快,但存储时可能发生collision(冲突)。
哈希表大多使用open addressing来解决collision,此时search的时间复杂度计算公式为:
1/( 1 - n/m )
其中,n与m分别表示存储的记录数与哈希表的长度,即装填因子( load factor )
故,若哈希表半满,即 n/m >= 1/2,则每次的search次数可能会 >= 2
因此,为了保证Hash Table在 key/value 查找模式中的优势,一般,其存储效率不会超过50%。
以上就是小编为大家带来的浅谈哈希表存储效率一般不超过50%的原因全部内容了,希望大家多多支持脚本之家~
您可能感兴趣的文章:
- 一文彻底搞定Java哈希表和哈希冲突
- Java代码实现哈希表(google 公司的上机题)
- PHP哈希表实现算法原理解析
- JAVA中哈希表HashMap的深入学习
- 使用python实现哈希表、字典、集合操作
- python 哈希表实现简单python字典代码实例
- java数据结构和算法中哈希表知识点详解
- JS模拟实现哈希表及应用详解
- C语言基于哈希表实现通讯录
- C++ 实现哈希表的实例
- js实现HashTable(哈希表)的实例分析
- C#中哈希表(HashTable)用法实例详解(添加/移除/判断/遍历/排序等)
- JavaScript中实现键值对应的字典与哈希表结构的示例
- 轻松学习C#的哈希表
- PHP内核探索:哈希表碰撞攻击原理
- java中哈希表及其应用详解
- C#使用foreach遍历哈希表(hashtable)的方法
- Java实现哈希表的基本功能