鸽笼原理(抽屉原理)

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

如果把 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)。
相关推荐
Jack2012 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树14 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint4562 天前
C++进阶(1)——前景提要
c++
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
夜悊2 天前
C++代码示例:进制数简单生成工具
c++