组合数学之容斥原理
2016-04-06 20:17
127 查看
在组合数学中,容斥是常常被用到的,我们总用容斥求解一些带有条件的组合数。
容斥原理:具有性质A和性质B的元素个数等同于具有性质A的个数和具有性质B的个数的和再减去同时具有性质A和性质B的元素的个数。
数学公式表示为 |A∪B|=|A|+|B|-|A∩B|。
图形表示为
其中黄色区域就是我们所求。
同样以此类推对于三个性质来说其数学公式为|A∪B∪C|=|A|+|B|+|C|-|A∩B|-|A∩C|-|B∩C|+|A∩B∩C|
为什么要加上最后那个呢?因为在减的过程中多减了一个。
对于容斥原理来说比较常用的方法为递归法和二进制枚举法,二进制枚举的方法最大的好处是枚举出所有元素的子集。假设一个集合的元素有m个,则对于m长的二进制数来说就有m个1或0的位置,对于每一个1
-就对应一个元素,整个二进制枚举完就是所有子集,从0到2^m就行。
递归法则是利用dfs的思想进行搜索,检索每一种方案进行容斥。由于每一种题都有不同的搜索方法,没用统一的模板,就不弄代码了。
在这其中都是奇数个性质加偶数个性质减,而如果所求的性质是相反的性质,则用总数减去。
容斥原理开着简单,实际非常复杂,每一道题都用不同的性质容斥,但最终的思想是不变的,多做一些题就会慢慢积累经验最终由一个好的思想。
容斥原理:具有性质A和性质B的元素个数等同于具有性质A的个数和具有性质B的个数的和再减去同时具有性质A和性质B的元素的个数。
数学公式表示为 |A∪B|=|A|+|B|-|A∩B|。
图形表示为
其中黄色区域就是我们所求。
同样以此类推对于三个性质来说其数学公式为|A∪B∪C|=|A|+|B|+|C|-|A∩B|-|A∩C|-|B∩C|+|A∩B∩C|
为什么要加上最后那个呢?因为在减的过程中多减了一个。
对于容斥原理来说比较常用的方法为递归法和二进制枚举法,二进制枚举的方法最大的好处是枚举出所有元素的子集。假设一个集合的元素有m个,则对于m长的二进制数来说就有m个1或0的位置,对于每一个1
-就对应一个元素,整个二进制枚举完就是所有子集,从0到2^m就行。
递归法则是利用dfs的思想进行搜索,检索每一种方案进行容斥。由于每一种题都有不同的搜索方法,没用统一的模板,就不弄代码了。
在这其中都是奇数个性质加偶数个性质减,而如果所求的性质是相反的性质,则用总数减去。
容斥原理开着简单,实际非常复杂,每一道题都用不同的性质容斥,但最终的思想是不变的,多做一些题就会慢慢积累经验最终由一个好的思想。
相关文章推荐
- Codeforces Round #198 (Div. 1)
- 4495: Least Prime factor 找到最小质因子P的第N小正整数
- hdu5072 Coprime 2014鞍山现场赛C题 容斥原理+单色三角
- 二维树状数组
- HDU 1695 GCD
- ZOJ 3547 《The Boss on Mars》(容斥定理)
- USACO 2.3.2 Cow Pedigrees
- USACO 2.3.2 Cow Pedigrees
- hdu1695 综合数论 欧拉函数 分解质因子 容斥原理 打印素数表 各种模板
- 1284 2 3 5 7的倍数
- gcdlcm[组合数学]
- hdu1695 GCD(容斥原理+欧拉函数)
- 关于容斥原理
- hdu1796(容斥原理)
- HDU 4135 Co-prime(容斥原理求互质数)
- hdu1796--How many integers can you find--容斥原理
- HDU 4135&HDU 4407--容斥原理--质因子分解
- HDU 5468 Puzzled Elena (2015年上海赛区网络赛A题)
- 【SDOI2013】【BZOJ3198】spring
- 【CQOI2014】【BZOJ3505】数三角形