哈希表、哈希冲突
哈希表
在哈希表中进行数据操作时性能很高,不考虑哈希冲突的情况下,仅需一次定位即可完成,时间复杂度为O(1)。
我们知道数据结构的物理存储结构有两种:顺序存储结构和链式存储结构。
而数组是根据下标查找某个元素的,一次定位就可以达到,哈希表利用了这种特性,哈希表的主干就是数组。
比如我们要新增或查找某个元素,我们通过把当前元素的key(关键字) 通过某个函数映射到数组中的某个位置,通过数组下标一次定位就可完成操作。
这个函数可以简单描述为:存储位置 = f(key) ,这个函数f一般称为哈希函数。
哈希冲突
添加数据时,如果两个不同的元素,通过哈希函数得出的实际存储地址相同,就会产生哈希冲突,也叫哈希碰撞。也就是要进行新元素插入时,发现对应地址已经被存在其他元素。
因此哈希函数的设计至关重要,好的哈希函数会尽可能地保证计算简单并且散列地址分布均匀,但是,数组是一块连续的固定长度的内存空间,再好的哈希函数也不能保证得到的存储地址绝对不发生冲突。
解决哈希冲突
- 种开放定址法(发生冲突,继续寻找下一块未被占用的存储地址),
- 再散列函数法
- 链地址法(HashMap用的这种,使用数组+链表的形式)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端