UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举)
UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举)
题意分析
给出n*m的矩形格子,给出k个点,每个格子里面可以放一个点。现在要求格子的最外围一圈的每行每列,至少要放一个点,并且放在角上的点,同时算那个角所在的行和所在的列。不允许剩下点,求总共的方案数量,结果对1000007取模。
数据范围2 ≤ M,N ≤ 20,K ≤ 500。
考虑到要求组合数目,首先就需要预处理500以内的组合数。正向求解可能有些困难,这样考虑:
不管三七二十一,先求解出所有情况的总和,即C(n*m,k),之后计算出不符合情况的,减去即可。
对于上下左右四条边,设第一行不放的集合为A,最后一行不放的集合为B,第一列不放的集合为C,最后一列不放的集合为D。根据排列组合可以知道,不合法的情况总数有2^4-1 = 15种。对于这15种,就可以用容斥原理求解出来,tot = (A+B+C+D) - ( (A∩B) + (A∩C) + (A∩D) + (B∩C) + (B∩D) + (C∩D) ) + ( (A∩B∩C) + (A∩B∩D) + (A∩C∩D) + (B∩C∩D) ) - (A∩B∩C∩D)(这个就是容斥原理). 共15项,计算之后分别减去即可。
接着对问题转化,第一行不放是什么意思呢?就是选择范围少了一行,即C((m-1)*n,k)。
然后对于容斥求出来的公式,如何进行计算呢?
发现,当所求的集合时奇数个的时候,要从总数中减去(黑体加粗的式子是正号,因为算的是不符合的情况,减去时要整体填一个负号),例如A,B,C,D四项均是一个集合,而(A∩B∩C∩D)就是四个集合。对于集合个数是偶数个的时候,就要加上。做到这一点,也十分容易,用二进制枚举即可。
代码总览
#include <cstdio>
#include <algorithm>
#include <cstring>
#define nmax 505
using namespace std;
int C[nmax][nmax];
int T;
const int MOD = 1000007;
void init()
{
memset(C,0,sizeof C);
C[0][0] = 1;
for(int i = 1;i<nmax;++i){
C[i][0] = C[i][i] = 1;
for(int j = 1;j<nmax;++j){
C[i][j] = (C[i-1][j-1] + C[i-1][j]) % MOD;
}
}
}
int main()
{
//freopen("in.txt","r",stdin);
init();
scanf("%d",&T);
for(int kase = 1;kase <= T; kase++){
int n,m,k;
scanf("%d %d %d",&m,&n,&k);
int up = 1,down = 2,left = 4,right = 8;
int ans = 0;
for(int i = 0;i<16;++i){
int column = n,line = m,index = 0;
if(up&i) column--,index++;
if(down&i) column--,index++;
if(left&i) line--,index++;
if(right&i) line--,index++;
if(index&1){
ans = (ans - C[column * line][k]) % MOD;
}else{
ans = (ans + C[column * line][k] + MOD) % MOD;
}
}
printf("Case %d: ",kase);
printf("%d\n",ans);
}
return 0;
}
UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举)的更多相关文章
- UVa 11806 Cheerleaders (容斥原理+二进制表示状态)
In most professional sporting events, cheerleaders play a major role in entertaining the spectators. ...
- 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 (容斥原理)
题意:在N*M个方格中放K个点,要求第一行,第一列,最后一行,最后一列必须放,问有多少种方法. 分析: 1.集合A,B,C,D分别代表第一行,第一列,最后一行,最后一列放. 则这四行必须放=随便放C[ ...
- UVA 11806 Cheerleaders (容斥原理
1.题意描述 本题大致意思是讲:给定一个广场,把它分为M行N列的正方形小框.现在给定有K个拉拉队员,每一个拉拉队员需要站在小框内进行表演.但是表演过程中有如下要求: (1)每一个小框只能站立一个拉拉队 ...
- UVa 11806 Cheerleaders (数论容斥原理)
题意:给定一个n*m的棋盘,要放k个石子,要求第一行,最后一行,第一列,最后一列都有石子,问有多少种放法. 析:容斥原理,集合A是第一行没有石子,集合B是最后一行没有石子,集合C是第一列没有石子,集合 ...
- uva 11806 Cheerleaders
// uva 11806 Cheerleaders // // 题目大意: // // 给你n * m的矩形格子,要求放k个相同的石子,使得矩形的第一行 // 第一列,最后一行,最后一列都必须有石子. ...
- UVA 11806 Cheerleaders (组合+容斥原理)
自己写的代码: #include <iostream> #include <stdio.h> #include <string.h> /* 题意:相当于在一个m*n ...
- UVA 11806 Cheerleaders (容斥原理)
题意 一个n*m的区域内,放k个啦啦队员,第一行,最后一行,第一列,最后一列一定要放,一共有多少种方法. 思路 设A1表示第一行放,A2表示最后一行放,A3表示第一列放,A4表示最后一列放,则要求|A ...
随机推荐
- 006 --MySQL索引原理
一 .索引的概念? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此对查询语句的优化 ...
- Git知识点整合
Git安装 Windows上安装Git 64 位安装包下载地址 : https://github.com/git-for-windows/git/releases/download/v2.16.2.w ...
- 一种利用ADO连接池操作MySQL的解决方案(VC++)
VC++连接MySQL数据库 常用的方式有三种:ADO.mysql++,mysql API ; 本文只讲述ADO的连接方式. 为什么要使用连接池? 对于简单的数据库应用,完全可以先创建一个常连接(此连 ...
- Windows下的ROUGE文本测评工具基本安装
需要的安装包: rouge1.5.5:https://pan.baidu.com/s/1B7-LYn1lZKC8f51yXxNK9w Strawberry Perl :http://strawberr ...
- Qt tableWidget 空单元格 获取选中行行号
bool focus = tableWidget->isItemSelected(tableWidget->currentItem()); // 判断是否选中一行 Int row1 = t ...
- 占位符golang
定义示例类型和变量 type Human struct { Name string } var people = Human{Name:"zhangsan"} 普通占位符 占位符 ...
- 20181023-11 Alpha发布
此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2283 文案: Learning by Playing 界面清爽明快,UI ...
- 第三次实验报告 敏捷开发与XP实践
一. 实验内容 (一)敏捷开发与XP 摘要:一项实践在XP环境中成功使用的依据通过XP的法则呈现,包括:快速反馈.假设简单性.递增更改.提倡更改.优质工作.XP软件开发的基石是XP的活动,包括:编码 ...
- Task 6.1 校友聊之NABCD模型分析
我们团队开发的一款软件是“校友聊”--一个在局域网内免流量进行文字.语音.视频聊天的软件.下面将对此进行NABCD的模型分析. N(Need需求):现如今,随着网络的迅速普及,手机和电脑已经成为每个大 ...
- bata5
目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:恺琳 组员6:翟丹丹 组员7:何家伟 组员8:政演 组员9:黄鸿杰 组员10:刘一好 组员11:何宇恒 展示 ...