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

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

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

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

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

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

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

你可能感兴趣的文章
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>