抽屉原理

抽屉原理,亦称鸽巢原理(the pigeonhole principle)。
它常被用于证明存在性证明和求最坏情况下的解。

简单情况

n+1 个物体,划分为 n 组,那么有至少一组有两个(或以上)的物体。

这个定理看起来比较显然,证明方法考虑反证法:假如每个分组有至多 1 个物体,那么最多有 1\times n 个物体,而实际上有 n+1 个物体,矛盾。

推广

n 个物体,划分为 k 组,那么至少存在一个分组,含有大于或等于 \left \lceil \dfrac{n}{k} \right \rceil 个物品。

推广的形式也可以使用反证法证明:若每个分组含有小于 \left \lceil \dfrac{n}{k} \right \rceil 个物体,则其总和 S\leq (\left \lceil \dfrac{n}{k} \right \rceil -1 ) \times k=k\left\lceil \dfrac{n}{k} \right\rceil-k < k(\dfrac{n}{k}+1)-k=n 矛盾。

此外,划分还可以弱化为覆盖结论不变。
给定集合 S , 一个 S 的非空子集构成的簇 \{A_1,A_2\ldots A_k\}

  • 若满足 \bigcup_{i=1}^k A_i 则称为 S 的一个覆盖(cover)
  • 若一个覆盖还满足 i\neq j\to A_i\cap A_j=\varnothing 则称为 S 的一个划分。

鸽巢原理可以有如下叙述:对于 S 的一个覆盖 \{A_1,A_2\ldots A_k\} 有至少一个集合 A_i 满足 \left\vert A_i \right\vert \geq \left\lceil \dfrac{\left\vert S \right\vert}{k} \right\rceil

参考文献


Comments