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 (组合数学 容斥原理 二进制枚举)的更多相关文章

  1. UVa 11806 Cheerleaders (容斥原理+二进制表示状态)

    In most professional sporting events, cheerleaders play a major role in entertaining the spectators. ...

  2. HDU.1796 How many integers can you find ( 组合数学 容斥原理 二进制枚举)

    HDU.1796 How many integers can you find ( 组合数学 容斥原理 二进制枚举) 题意分析 求在[1,n-1]中,m个整数的倍数共有多少个 与 UVA.10325 ...

  3. UVA.10325 The Lottery (组合数学 容斥原理 二进制枚举)

    UVA.10325 The Lottery (组合数学 容斥原理) 题意分析 首先给出一个数n,然后给出m个数字(m<=15),在[1-n]之间,依次删除给出m个数字的倍数,求最后在[1-n]之 ...

  4. UVA - 11806 Cheerleaders (容斥原理)

    题意:在N*M个方格中放K个点,要求第一行,第一列,最后一行,最后一列必须放,问有多少种方法. 分析: 1.集合A,B,C,D分别代表第一行,第一列,最后一行,最后一列放. 则这四行必须放=随便放C[ ...

  5. UVA 11806 Cheerleaders (容斥原理

    1.题意描述 本题大致意思是讲:给定一个广场,把它分为M行N列的正方形小框.现在给定有K个拉拉队员,每一个拉拉队员需要站在小框内进行表演.但是表演过程中有如下要求: (1)每一个小框只能站立一个拉拉队 ...

  6. UVa 11806 Cheerleaders (数论容斥原理)

    题意:给定一个n*m的棋盘,要放k个石子,要求第一行,最后一行,第一列,最后一列都有石子,问有多少种放法. 析:容斥原理,集合A是第一行没有石子,集合B是最后一行没有石子,集合C是第一列没有石子,集合 ...

  7. uva 11806 Cheerleaders

    // uva 11806 Cheerleaders // // 题目大意: // // 给你n * m的矩形格子,要求放k个相同的石子,使得矩形的第一行 // 第一列,最后一行,最后一列都必须有石子. ...

  8. UVA 11806 Cheerleaders (组合+容斥原理)

    自己写的代码: #include <iostream> #include <stdio.h> #include <string.h> /* 题意:相当于在一个m*n ...

  9. UVA 11806 Cheerleaders (容斥原理)

    题意 一个n*m的区域内,放k个啦啦队员,第一行,最后一行,第一列,最后一列一定要放,一共有多少种方法. 思路 设A1表示第一行放,A2表示最后一行放,A3表示第一列放,A4表示最后一列放,则要求|A ...

随机推荐

  1. Datawhale MySQL 训练营 Task6 实战项目

    作业 项目十:行程和用户(难度:困难) Trips 表中存所有出租车的行程信息.每段行程有唯一键 Id,Client_Id 和 Driver_Id 是 Users 表中 Users_Id 的外键.St ...

  2. JavaScript学习要点

    Javascript相关内容 1.序列化--json - stringify() 将对象转换为字符串 - parse() 将字符串转换为对象 list=[11,22,33,44,55]; 结果:(5) ...

  3. Leetcode_3. Find the longest substring without repeating characters

    3. Find the longest substring without repeating characters Given a string, find the length of the lo ...

  4. 纯命令行界面下安装并运行官方Android emulator

    纯命令行界面指没有安装Android studio. 下载sdk-tools 可以根据实际需要下载,不需要FQ(2018-04-07) 下载后只有一个tools目录. 平台 SDK 工具包 大小 SH ...

  5. IOS statusBarStyle 设置

    在项目info.plist文件中有 View controller-based status bar appearance 属性. 当设置为NO时 通过 [UIApplication sharedAp ...

  6. [leetcode-921-Minimum Add to Make Parentheses Valid]

    Given a string S of '(' and ')' parentheses, we add the minimum number of parentheses ( '(' or ')', ...

  7. Bing词典vs有道词典比对测试报告——体验篇之软件适应性

    联网情况: 在联网情况下,针对每一次查询,有道词典的反应速度明显比必应词典快得多.据我推测有以下两个原因: 有道词典有本地词库而必应词典更多依赖联网. 有道词典的服务器在国内而必应的在国外. 断网情况 ...

  8. model类的构造部分属性的对象 产生的json

    在 action方法里, 产生一个对象,可能会是默认的全属性对象,那么在输出的 json就又所有 都出现了. 只是其他的属性全部是 null 那么 在 json里面配上 <!-- json 不产 ...

  9. mvc的过滤器学习-资料查询

    标题:Filtering in ASP.NET MVC 地址:https://docs.microsoft.com/en-us/previous-versions/aspnet/gg416513(v= ...

  10. # 团队UML设计

    团队信息 学号 姓名 博客链接 124 王彬(组长) 点击这里 206 赵畅 点击这里 215 胡展瑞 点击这里 320 李恒达 点击这里 131 佘岳昕 点击这里 431 王源 点击这里 206 陈 ...