博客
关于我
鸽巢原理(抽屉原理)
阅读量:614 次
发布时间:2019-03-13

本文共 385 字,大约阅读时间需要 1 分钟。

鸽巢原理解释了一个经典的计算机科学概念:当将n个物品放入m个容器中(n > m),至少有一个容器中将包含超过1个物品。这一原理经常被用来解释哈希冲突的存在性。

哈希表是一种用于数据存储和检索的数据结构,由哈希函数将键映射为内存地址。理论上,每个键都应该映射到唯一的地址(即单个鸽巢),但现实中,哈希函数的inedquate区分度会导致多个键(鸽子)被错误地映射到相同的地址(鸽巢),这是我们所说的哈希冲突。

这个问题与原始鸽巢问题相似:当存储的内容多于鸽巢的数量时,某些鸽巢必定会有多于一只鸽子。同样的道理适用于哈希表:由于哈希函数无法保证完全的唯一性,冲突的出现是可以预见且不可避免的。

因此,哈希冲突并不是一个数学上的 缺陷,而是反映了我们使用哈希函数的本质限制之一。在实际应用中,我们通常通过调节哈希函数的设计和大小再次尝试,以减少冲突的发生率,但绝少能完全消除。

转载地址:http://gvyaz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现Horn–Schunck光流算法(附完整源码)
查看>>
Objective-C实现Http Post请求(附完整源码)
查看>>
Objective-C实现http下载文件 (附完整源码)
查看>>
Objective-C实现Http协议下载文件(附完整源码)
查看>>
Objective-C实现huffman哈夫曼编码算法(附完整源码)
查看>>
Objective-C实现ID3贪心算法(附完整源码)
查看>>
Objective-C实现IIR 滤波器算法(附完整源码)
查看>>
Objective-C实现IIR数字滤波器(附完整源码)
查看>>
Objective-C实现insertion sort插入排序算法(附完整源码)
查看>>
Objective-C实现integer partition整数分区算法(附完整源码)
查看>>
Objective-C实现integerPartition整数划分算法(附完整源码)
查看>>
Objective-C实现interpolation search插值搜索算法(附完整源码)
查看>>
Objective-C实现Interpolation search插值查找算法(附完整源码)
查看>>
Objective-C实现intersection交集算法(附完整源码)
查看>>
Objective-C实现intro sort内省排序算法(附完整源码)
查看>>
Objective-C实现inverse matrix逆矩阵算法(附完整源码)
查看>>
Objective-C实现inversions倒置算法(附完整源码)
查看>>
Objective-C实现isalpha函数功能(附完整源码)
查看>>
Objective-C实现islower函数功能(附完整源码)
查看>>
Objective-C实现isPowerOfTwo算法(附完整源码)
查看>>