鸽笼原理(抽屉原理)

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

如果把 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)。
相关推荐
QiLinkOS32 分钟前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
Irissgwe1 小时前
c++11(lambda表达式与包装器、线程库)
c++·c++11·lambda表达式·线程库·包装器·互斥量库·条件变量库
小白兔奶糖ovo1 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll1 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程2 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan2 小时前
算法日记 | 暴力枚举
学习·算法
s_w.h2 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
不想写代码的星星2 小时前
从分支预测角度看 C++:为什么你的热循环慢得离谱?
c++
过期动态2 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
春日见2 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉