浅谈哈希表存储效率一般不超过50%的原因
2017-01-06 09:01
627 查看
本文主要是讲"哈希表的存储效率一般不超过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%的原因全部内容了,希望大家多多支持脚本之家~
相关文章推荐
- 认识存储:块、文件和对象
- 通过更换硬盘舱位的方式解决存储问题
- Tomcat端口被占用解决方法(不用重启)
- “传奇”图象数据存储方式
- Windows Powershell使用哈希表
- 探索PowerShell (八) 数组、哈希表(附:复制粘贴技巧)
- 通用SQL存储过程分页以及asp.net后台调用的方法
- 超大数据量存储常用数据库分表分库算法总结
- 轻松学习C#的哈希表
- SQL Server误区30日谈 第18天 有关FileStream的存储,垃圾回收以及其它
- C++实现图的邻接表存储和广度优先遍历实例分析
- 详解Android文件存储
- C#中哈希表(HashTable)用法实例详解(添加/移除/判断/遍历/排序等)
- C#调用sql2000存储过程方法小结
- PHP 存储文本换行实现方法
- 注册表中存储数据库链接字符串的方法
- Mysql中存储UUID去除横线的方法
- PHP内核探索:哈希表碰撞攻击原理
- MySQLMerge存储引擎
- 深入PHP变量存储的详解