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

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

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

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

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

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

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

你可能感兴趣的文章
MySQL系列之数据类型(Date&Time)
查看>>
MySQL系列之数据类型(Date&Time)
查看>>
Mysql系列之锁机制
查看>>
Mysql系列九:使用zookeeper管理远程Mycat配置文件、Mycat监控、Mycat数据迁移(扩容)...
查看>>
Mysql索引
查看>>
mysql索引
查看>>
mysql索引
查看>>
Mysql索引,索引的优化,如何避免索引失效案例
查看>>
Mysql索引、命令重点介绍
查看>>
mysql索引、索引优化(这一篇包括所有)
查看>>
MySQL索引一篇带你彻底搞懂(一次讲清实现原理加优化实战,面试必问)
查看>>
MySql索引为什么使用B+树
查看>>
WARNING!VisualDDK wizard was unable to find any DDK/WDK installed on your system.
查看>>
Mysql索引优化
查看>>
MySQl索引创建
查看>>
mysql索引创建及使用注意事项
查看>>
mysql索引创建和使用注意事项
查看>>
MySQL索引原理以及查询优化
查看>>
Mysql索引合并(index merge)导致的死锁问题
查看>>
mysql索引底层数据结构和算法
查看>>