组合数学:容斥原理(HDU1976)
●容斥原理所研究的问题是与若干有限集的交、并或差有关的计数.
●在实际中, 有时要计算具有某种性质的元素个数.
例:
某单位举办一个外语培训班, 开设英语, 法语两门课.设U为该单位所有人集合, A,B分别为学英语, 法语人的集合, 如图所示.
学两门外语的人数为|AB|,
只学一门外语的人数为|AB|-|AB|,
没有参加学习的人数为|U|-|AB|.
在一些计数问题中, 经常遇到间接计算一个集合中具有某种性质的元素个数比起直接计算来得简单.
例如: 计算1到700之间不能被7整除的整数个数.
先计算1到700之间能被7整除的整数个数=700/ 7=100, 所以1到700之间不能被7整除的整数个数=700-100=600.
上面举的间接计数的例子是利用了如下原理:如果A是集合S的子集, 则A中的元素个数等于S中的元素个数减去不在A中的元素个数, 这个原理可写成:
● 原理的重要推广, 称之为容斥原理,并且将它运用到若干问题上去, 其中包括:
错位排列、
有限制的排列、
禁位排列和
棋阵多项式等.
容斥原理:
DeMorgan定理:设A,B为全集U的任意两个子集,则
DeMorgan定理的推广:设A1, A2……An为U的子集,则
1.两个集合的容斥原理:
2.三个集合的容斥原理:
3.n个集合上的容斥原理:
4.余集形式:
错牌问题——容斥定理的应用实例
(1..n)的错位排列个数记为Dn. 结论如下:
可以用容斥原理证明:
设S={1,2,3,,n}的集合, S0为S的全排列,则s0=n! . 令Aj表示排列1,2n中使j位置上的元素恰好是j的排列的集合, j=1,2,,n. 则排列12n的所有错位排列组成集合:
因为{1,2,3,,n}的k组合为C(n,k)个,
应用容斥原理得到:
HDU1796 How many intergers can you find
How many integers can you find
Time Limit: 12000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 6281 Accepted Submission(s): 1804
Problem Description
Now you get a number N, and a M-integers set, you should find out how many integers which are small than N, that they can divided exactly by any integers in the set. For example, N=12, and M-integer set is {2,3}, so there is another set {2,3,4,6,8,9,10}, all the integers of the set can be divided exactly by 2 or 3. As a result, you just output the number 7.
Input
There are a lot of cases. For each case, the first line contains two integers N and M. The follow line contains the M integers, and all of them are different from each other. 0<N<2^31,0<M<=10, and the M integer are non-negative and won’t exceed 20.
Output
For each case, output the number.
Sample Input
12 2
2 3
Sample Output
7
Author
wangye
Source
2008 “Insigma International Cup” Zhejiang Collegiate Programming Contest - Warm Up(4)
Recommend
wangye
//**************************************************************************************************
/*
容斥原理的题目,并且同时包含了dfs和欧几里得算法。
*/
//************************************************************************************************** #include<cstdio>
#include<cstring>
#include<iostream> using namespace std; const int MAXN = ;
int p[MAXN];
int n;
int m;
int Result; int GCD(int a, int b) { //欧几里得算法,求最大公约数。
if (b == ) return a;
else return GCD(b, a % b); //辗转相除。
} int LCM(int a, int b) { //求最小公倍数。
return a / GCD(a, b) * b;
} int DFS(int n) { //深度优先搜索实现容斥原理。
int i, j;
int Cnt_Manifold; //遍历到的数的数量(数集的数量)。
int Least_Common_Multiple; //遍历到的Cnt_Manifold个数的最小公倍数。
Result = ; //记录每次深度搜索的结果。
for (i = ; i < ( << m); i++) { //i的二进制位代表此次遍历查找的是那几个数
Cnt_Manifold = ;
Least_Common_Multiple = ; //1与任何数的最小公倍数还是那个数本身,所以初值赋为1.
for (j = ; j < m; j++)
if (i & ( << j)) { //筛选出要找的数并求出他们的最小公倍数。
Cnt_Manifold++;
Least_Common_Multiple = LCM(Least_Common_Multiple, p[j]);
}
if (Cnt_Manifold & ) { //奇数个为正偶数个为负,其作用相当于(-1)^(n - 1).
Result += n / Least_Common_Multiple;
}
else {
Result -= n / Least_Common_Multiple;
}
}
return Result;
} int main() {
int cnt;
int temp;
while (cin >> n >> m) {
cnt = ;
for (int i = ; i < m; i++) {
cin >> temp;
if (temp) {
p[cnt++] = temp;
}
}
m = cnt;
cout << DFS(n - ) << endl;
}
return ;
}
组合数学:容斥原理(HDU1976)的更多相关文章
- BZOJ_3129_[Sdoi2013]方程_组合数学+容斥原理
BZOJ_3129_[Sdoi2013]方程_组合数学+容斥原理 Description 给定方程 X1+X2+. +Xn=M 我们对第l..N1个变量进行一些限制: Xl < = A ...
- HDU.1796 How many integers can you find ( 组合数学 容斥原理 二进制枚举)
HDU.1796 How many integers can you find ( 组合数学 容斥原理 二进制枚举) 题意分析 求在[1,n-1]中,m个整数的倍数共有多少个 与 UVA.10325 ...
- UVA.10325 The Lottery (组合数学 容斥原理 二进制枚举)
UVA.10325 The Lottery (组合数学 容斥原理) 题意分析 首先给出一个数n,然后给出m个数字(m<=15),在[1-n]之间,依次删除给出m个数字的倍数,求最后在[1-n]之 ...
- UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举)
UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举) 题意分析 给出n*m的矩形格子,给出k个点,每个格子里面可以放一个点.现在要求格子的最外围一圈的每行每列,至少要放一个 ...
- 【BZOJ 3294】 3294: [Cqoi2011]放棋子 (DP+组合数学+容斥原理)
3294: [Cqoi2011]放棋子 Description Input 输入第一行为两个整数n, m, c,即行数.列数和棋子的颜色数.第二行包含c个正整数,即每个颜色的棋子数.所有颜色的棋子总数 ...
- BZOJ4710: [Jsoi2011]分特产 组合数学 容斥原理
题意:把M堆特产分给N个同学,要求每个同学至少分到一种特产,共有多少种分法? 把A个球分给B个人的分法种数:(插板法,假设A个球互不相同,依次插入,然后除以全排列去重) C(A,B+A) 把M堆特产分 ...
- BZOJ4767: 两双手【组合数学+容斥原理】
Description 老W是个棋艺高超的棋手,他最喜欢的棋子是马,更具体地,他更加喜欢马所行走的方式.老W下棋时觉得无聊,便决定加强马所行走的方式,更具体地,他有两双手,其中一双手能让马从(u,v) ...
- 【bzoj4305】数列的GCD 组合数学+容斥原理
题目描述 给出一个长度为N的数列{a[n]},1<=a[i]<=M(1<=i<=N). 现在问题是,对于1到M的每个整数d,有多少个不同的数列b[1], b[2], ..., ...
- BZOJ4767 两双手(组合数学+容斥原理)
因为保证了两向量不共线,平面内任何一个向量都被这两个向量唯一表示.问题变为一张有障碍点的网格图由左上走到右下的方案数. 到达终点所需步数显然是平方级别的,没法直接递推.注意到障碍点数量很少,那么考虑容 ...
随机推荐
- Uri、UriMatcher、ContentUris详解
http://blog.csdn.net/feng88724/article/details/6331396 1.Uri 通用资源标志符(Universal Resource Identifier, ...
- Android Service初步学习的笔记
1.Service的应用场景 条件:a.并不依赖于用户可视化界面(不是绝对的,如前台service就是与notification界面结合使用的) b.具有较长时间的运行特性. service的应用 ...
- 在使用Kettle的集群排序中 Carte的设定——(基于Windows)
本片文章主要是关于使用Kettle的UI界面: Spoon来实现基于集群的对数据库中的数据表数据进行排序的试验. 以及在实验过程中所要开启的Carte服务的一些配置文件的设置, 还有基于Windows ...
- ubuntu系统安装的MySql数据库,远程不能访问的几种可能问题
安装MySQL数据库后一般会遇到远程计算机不能连接的问题,具体问题需要我们排查.可能一:MySql数据库是否提供了外部访问的用户以及权限?可能二:MySql的配置文件是否只绑定了本机ip(ubuntu ...
- 4 - 执行TestNG
TestNG以如下几种方式被调用 命令行 ant Eclipse IntelliJ's IDEA 这部分对如何使用命令行方式调用TestNG进行阐述. 假设TestNG已经在你的classpath中, ...
- centos lnmp 安装笔记
[root@host]# chkconfig nginx on [root@host]# service nginx start [root@host]# service nginx stop [ro ...
- dedecms 修改标题长度可以修改数据库
数据表为dede__archives 字段为title 首先要在 a.系统->系统基本参数->其它选项->文章标题长度 b.系统->SQL命令行工具 alter table # ...
- 谈谈android 布局 的优化
来自:http://www.cnblogs.com/youxilua/archive/2012/05/08/2489414.html 导言 设配android的屏幕一定是一个噩梦,就好比那些搞网页设计 ...
- 删除svn文件
删除svn文件 sudo find . -name ".DS_Store" -exec rm -r {} \; sudo find . -name ".git" ...
- 编译内核出错:invalid option `abi=aapcs-linux' 解决办法
出现此问题的原因是由于kernel feature中选中了Use the ARM EABIto compile the kernel引起的,有两各解决办法: 1)换编译器为arm-linux-gcc ...