容斥原理
引入
入门例题
假设班里有 个学生喜欢数学, 个学生喜欢语文, 个学生喜欢编程,班里至少喜欢一门学科的有多少个学生呢?
是 个吗?不是的,因为有些学生可能同时喜欢数学和语文,或者语文和编程,甚至还有可能三者都喜欢。
为了叙述方便,我们把喜欢语文、数学、编程的学生集合分别用 表示,则学生总数等于 。刚才已经讲过,如果把这三个集合的元素个数 直接加起来,会有一些元素重复统计了,因此需要扣掉 ,但这样一来,又有一小部分多扣了,需要加回来,即 。即

把上述问题推广到一般情况,就是我们熟知的容斥原理。
定义
设 U 中元素有 n 种不同的属性,而第 i 种属性称为 ,拥有属性 的元素构成集合 ,那么
即
证明
对于每个元素使用二项式定理计算其出现的次数。对于元素 x,假设它出现在 的集合中,那么它的出现次数为
于是每个元素出现的次数为 1,那么合并起来就是并集。证毕。
补集
对于全集 U 下的 集合的并 可以使用容斥原理计算,而集合的交则用全集减去 补集的并集 求得:
右边使用容斥即可。
可能接触过容斥的读者都清楚上述内容,而更关心的是容斥的应用。
那么接下来我们给出 3 个层次不同的例题来为大家展示容斥原理的应用。
不定方程非负整数解计数
不定方程非负整数解计数
给出不定方程 和 个限制条件 ,其中 . 求方程的非负整数解的个数。
没有限制时
如果没有 的限制,那么不定方程 的非负整数解的数目为 .
略证:插板法。
相当于你有 个球要分给 个盒子,允许某个盒子是空的。这个问题不能直接用组合数解决。
于是我们再加入 个球,于是问题就变成了在一个长度为 的球序列中选择 个球,然后这个 个球把这个序列隔成了 份,恰好可以一一对应放到 个盒子中。那么在 个球中选择 个球的方案数就是 。
容斥模型
接着我们尝试抽象出容斥原理的模型:
- 全集 U:不定方程 的非负整数解
- 元素:变量 .
- 属性: 的属性即 满足的条件,即 的条件
目标:所有变量满足对应属性时集合的大小,即 .
这个东西可以用 求解。 可以用组合数计算,后半部分自然使用容斥原理展开。
那么问题变成,对于一些 的交集求大小。考虑 的含义,表示 的解的数目。而交集表示同时满足这些条件。因此这个交集对应的不定方程中,有些变量有 下界限制,而有些则没有限制。
能否消除这些下界限制呢?既然要求的是非负整数解,而有些变量的下界又大于 ,那么我们直接 把这个下界减掉,就可以使得这些变量的下界变成 ,即没有下界啦。因此对于
的不定方程形式为
于是这个也可以组合数计算啦。这个长度为 的 数组相当于在枚举子集。
HAOI2008 硬币购物
硬币购物
4 种面值的硬币,第 i 种的面值是 。 次询问,每次询问给出每种硬币的数量 和一个价格 ,问付款方式。
.
如果用背包做的话复杂度是 ,无法承受。这道题最明显的特点就是硬币一共只有四种。抽象模型,其实就是让我们求方程 的非负整数解的个数。
采用同样的容斥方式, 的属性为 . 套用容斥原理的公式,最后我们要求解
也就是无限背包问题。这个问题可以预处理,算上询问,总复杂度 。
数论中的容斥
使用容斥原理能够巧妙地求解一些数论问题。
容斥原理求最大公约数为 k 的数对个数
考虑下面的问题:
求最大公约数为 $k$ 的数对个数
设 , 表示最大公约数为 的有序数对 的个数,求 到 的值。
这道题固然可以用欧拉函数或莫比乌斯反演的方法来做,但是都不如用容斥原理来的简单。
由容斥原理可以得知,先找到所有以 为 公约数 的数对,再从中剔除所有以 的倍数为 公约数 的数对,余下的数对就是以 为 最大公约数 的数对。即 以 为 公约数 的数对个数 以 的倍数为 公约数 的数对个数。
进一步可发现,以 的倍数为 公约数 的数对个数等于所有以 的倍数为 最大公约数 的数对个数之和。于是,可以写出如下表达式:
由于当 时,我们可以直接算出 ,因此我们可以倒过来,从 算到 就可以了。于是,我们使用容斥原理完成了本题。
上述方法的时间复杂度为 。
容斥原理一般化
容斥原理常用于集合的计数问题,而对于两个集合的函数 ,若
那么就有
证明
接下来我们简单证明一下。我们从等式的右边开始推:
我们发现后半部分的求和与 无关,因此把后半部分的 剔除:
记关于集合 的函数 ,并化简这个函数:
因此原来的式子的值是
分析发现,仅当 时有 ,这时 ,对答案的贡献就是 ,其他时侯 ,则对答案无贡献。于是得到
综上所述,得证。
推论
该形式还有这样一个推论。在全集 下,对于函数 ,如果
那么
这个推论其实就是补集形式,证法类似。