鸽笼原理(抽屉原理)

鸽笼原理(也叫抽屉原理)是一个非常简单但极其有用的组合数学原理。它的核心思想是:

如果把 n+1 个物体放入 n 个盒子中,那么至少有一个盒子里面含有 至少两个 物体。

更一般地,如果把 N 个物体放入 M 个盒子,且 N > M ,那么至少有一个盒子包含 ⌈N/M⌉ 个物体。

直观例子

  • 生日问题:367 个人中,至少有两个人生日相同(因为一年最多 366 天)。

  • 袜子配对:抽屉里有 10 只黑袜子和 10 只白袜子,黑暗中至少要拿出 3 只才能保证有一双同色(3 只袜子放入 2 种颜色的"盒子",必有一个颜色有 2 只)。

  • 握手问题:在任意 6 个人中,要么有 3 个人两两互相认识,要么有 3 个人两两互不认识(这其实是拉姆齐理论的简单特例,也用到鸽笼原理)。

在计算机科学中的应用

  • 哈希冲突:如果哈希表的桶数少于要存储的元素数,必然会发生冲突。

  • 数据压缩:无损压缩算法不可能将所有文件都压缩得更小(因为可能的短文件数目少于长文件数目,根据鸽笼原理,必有不同文件压缩后相同,无法解压)。

  • 算法分析:证明某些算法的最坏情况时间复杂度下界(例如,用比较排序的决策树高度)。

数学形式

  • 若函数 f:A→B且 ∣A∣>∣B∣,则 ff 不是单射(即存在 x1≠x2​ 使得 f(x1)=f(x2)。
相关推荐
m0_629494731 小时前
LeetCode 热题 100-----17.缺失的第一个正数
数据结构·算法·leetcode
Tisfy1 小时前
LeetCode 0796.旋转字符串:暴力模拟
算法·leetcode·题解·模拟·字符串匹配
BlockChain8881 小时前
AI+区块链深度探索:算法与账本的共生时代
人工智能·算法·区块链
生成论实验室2 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第一章 源:不可言说的生成之源
人工智能·科技·算法·生活·创业创新
2zcode2 小时前
基于低光照增强与轻量型CNN道路实时识别算法研究(UI界面+数据集+训练代码)
人工智能·算法·cnn·低光照增强·自动驾驶技术
郝学胜-神的一滴2 小时前
跨平台动态库与头文件:从原理到命名的深度解析
linux·c++·程序人生·unix·cmake
代码中介商2 小时前
C++ 仿函数(Functor)深度解析:从基础到应用
开发语言·c++
小雅痞2 小时前
[Java][Leetcode middle] 209. 长度最小的子数组
java·算法·leetcode
王老师青少年编程2 小时前
csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:[NOIP 2018 普及组] 标题统计
c++·字符串·csp·高频考点·信奥赛·专项训练·标题统计