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

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

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

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

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

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

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

你可能感兴趣的文章
MySql-2019-4-21-复习
查看>>
mysql-5.6.17-win32免安装版配置
查看>>
mysql-5.7.18安装
查看>>
MySQL-Buffer的应用
查看>>
mysql-cluster 安装篇(1)---简介
查看>>
mysql-connector-java.jar乱码,最新版mysql-connector-java-8.0.15.jar,如何愉快的进行JDBC操作...
查看>>
mysql-connector-java各种版本下载地址
查看>>
mysql-EXPLAIN
查看>>
MySQL-Explain的详解
查看>>
mysql-group_concat
查看>>
MySQL-redo日志
查看>>
MySQL-【1】配置
查看>>
MySQL-【4】基本操作
查看>>
Mysql-丢失更新
查看>>
Mysql-事务阻塞
查看>>
Mysql-存储引擎
查看>>
mysql-开启慢查询&所有操作记录日志
查看>>
MySQL-数据目录
查看>>
MySQL-数据页的结构
查看>>
MySQL-架构篇
查看>>