uva 11806 Cheerleaders
// uva 11806 Cheerleaders
//
// 题目大意:
//
// 给你n * m的矩形格子,要求放k个相同的石子,使得矩形的第一行
// 第一列,最后一行,最后一列都必须有石子.
//
// 解题思路:
//
// 容斥原理,我们这样考虑,如果只是n * m放石子,那么最后的结果
// 就是C(n*m,k).我们设A为第一行不放石头的总数,B为最后一行不放石子
// 的总数,C为第一列不放石子的总数,D为最后一列不放石子的总数.则问题
// 转化为在全集S中,求不在A,B,C,D部分的解.则答案为S - | A | - | B |
// - | C | - | D | + | A ^ B|......用一个二进制枚举状态,统计就可以了
//
// 感悟:
//
// 这道题,开始的时候,从正面做,看减去什么,但是最后都是把自己脑子搞糊涂
// 了,不知道自己在干什么,最后,就没有最后了,每次做题,都是这种感觉,看到解答
// 的时候,我才恍然大悟,原来可以这样啊,自己缺乏抽象思维,缺乏转换问题的思维
// 多说也没什么用,继续加油吧!FIGHTING #include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream> using namespace std; typedef long long ll; const int MAX_N = ;
const ll MOD = ;
ll C[MAX_N][MAX_N];
int n,m,k;
void init(){
C[][] = ;
for (int i=;i<MAX_N;i++){
C[i][] = C[i][i] = ;
for (int j=;j<i;j++)
C[i][j] = (C[i-][j-] + C[i-][j])%MOD;
}
} void input(){ scanf("%d%d%d",&n,&m,&k);
ll sum = ;
for (int S=;S<;S++){
int b = ,r = n,c = m;
if(S & ){
r--;
b++;
}
if (S & ){
r--;
b++;
}
if (S & ){
c--;
b++;
}
if (S & ){
c--;
b++;
}
if (b & )
sum = (sum + MOD - C[r * c][k])%MOD;
else
sum = (sum + C[r * c][k])%MOD;
}
cout << sum << endl;
} int main(){ int t;
init();
//freopen("1.txt","r",stdin);
scanf("%d",&t);
int kase = ;
while(t--){
printf("Case %d: ",kase++);
input();
}
}
uva 11806 Cheerleaders的更多相关文章
- UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举)
UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举) 题意分析 给出n*m的矩形格子,给出k个点,每个格子里面可以放一个点.现在要求格子的最外围一圈的每行每列,至少要放一个 ...
- UVA 11806 Cheerleaders dp+容斥
In most professional sporting events, cheerleaders play a major role in entertaining the spectators. ...
- UVa 11806 Cheerleaders (容斥原理+二进制表示状态)
In most professional sporting events, cheerleaders play a major role in entertaining the spectators. ...
- uva 11806 Cheerleaders (容斥)
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...
- UVA 11806 Cheerleaders (组合+容斥原理)
自己写的代码: #include <iostream> #include <stdio.h> #include <string.h> /* 题意:相当于在一个m*n ...
- UVA 11806 Cheerleaders (容斥原理)
题意 一个n*m的区域内,放k个啦啦队员,第一行,最后一行,第一列,最后一列一定要放,一共有多少种方法. 思路 设A1表示第一行放,A2表示最后一行放,A3表示第一列放,A4表示最后一列放,则要求|A ...
- UVA 11806 Cheerleaders (容斥原理
1.题意描述 本题大致意思是讲:给定一个广场,把它分为M行N列的正方形小框.现在给定有K个拉拉队员,每一个拉拉队员需要站在小框内进行表演.但是表演过程中有如下要求: (1)每一个小框只能站立一个拉拉队 ...
- 【递推】【组合数】【容斥原理】UVA - 11806 - Cheerleaders
http://www.cnblogs.com/khbcsu/p/4245943.html 本题如果直接枚举的话难度很大并且会无从下手.那么我们是否可以采取逆向思考的方法来解决问题呢?我们可以用总的情况 ...
- UVa 11806 - Cheerleaders (组合计数+容斥原理)
<训练指南>p.108 #include <cstdio> #include <cstring> #include <cstdlib> using na ...
随机推荐
- [2015hdu多校联赛补题]hdu5301 Buildings
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5301 题目大意:给你一块由1x1方格组成的矩形区域,其中有且仅有一个坏块,现在你要在上面建矩形的房子, ...
- EF测试自动修改数据库结构
1.配置类 <connectionStrings> <add name="test1" connectionString="Data Source=.; ...
- 深度学习(dropout)
other_techniques_for_regularization 随手翻译,略作参考,禁止转载 www.cnblogs.com/santian/p/5457412.html Dropout: D ...
- Reset CSS:只选对的,不选"贵"的
玉伯和正淳一起整理的一份 reset.css: /* KISSY CSS Reset 理念:清除和重置是紧密不可分的 特色:1.适应中文 2.基于最新主流浏览器 维护:玉伯(lifesinger@gm ...
- CentOS 6.5 安装Oracle 11G R2问题列表
1. 文章中写vi/etc/profile #这个很重要 if [ $USER ="oracle" ]; then if [ $SHELL="/bin/ksh&q ...
- 用POI读取具有任意合并单元的excel数据
maven依赖: <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</ ...
- 四元数(Quaternions)简介
经常在代码中看到Quaternions,也知道它是用来表达三维空间的旋转的,但一直没有更深的理解.这两天终于花点时间看了看维基百科的介绍,算是多了解了点.做个记录吧! 本质上而言,四元数是一个数学概念 ...
- Keepalived 配置实例
Keepalived 是一款轻量级HA集群应用,它的设计初衷是为了做LVS集群的HA,即探测LVS健康情况,从而进行主备切换,不仅如此,还能够探测LVS代理的后端主机的健康状况,动态修改LVS转发规则 ...
- AngularJs自定义指令详解(8) - priority
priority 默认值为0. 当一个元素上声明两个指令,而且它们的priority一样,谁先被调用?这个需要分情况讲.下面先给个例子: <!DOCTYPE html> <html& ...
- 学习html心得
最近我们小组在搞一个网站项目,每个组员都在学习html与css. 我们先找到相关网站寻找信息进行学习,内容不多,我很快就把html的教程看完了.感觉还不错,就下载了html编辑器Notepad++进行 ...