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 ...
随机推荐
- jQuery插件制作方法
html页面:<h1>Hello My name is Alex,i from china.</h1> 1.无参数实现文字阴影效果 测试代码: $("h1" ...
- C++STL学习笔记_(1)deque双端数组知识
#include<iostream> using namespace std; #include "deque" #include "algorithm&qu ...
- ASP.NET ZERO 学习 HangFire的使用
hangfire 是一个分布式后台执行服务. 官网:http://hangfire.io/ 1.启用 hangfire 2.Hangfire可以提供一个面板页面,实时显示所有后台作业的状态,你可以按它 ...
- vim--macro
例: qa some vim command q 这个宏只记录了vim命令到寄存器a中,执行这个宏可以用命令: @a 也可以加上执行次数: 10@a 执行10次 当你执行过一次@a之后,你可以用 @@ ...
- npm 加速方案
使用npm install 包,是见比较头疼的事情,比较慢,很难等,经过探索,还是发现有办法加速的,方法有两个,让我一一道来: 1. 在npm 后添加参数 --registry=... 指定镜像源地址 ...
- css 字间距、CSS字体间距、css 字符间距设置
1.text-indent设置抬头距离css缩进 2.letter-spacing来设置字与字间距_字符间距离,字体间距css样式
- 在windows下面配置redis集群遇到的一些坑
最近工作不忙,就决定学习一下redis.因为一直在windows下工作,不会linux,没办法就选择在windows下配置redis. windows下配置redis集群的文章有很多,比如:http: ...
- 基于webmagic的爬虫小应用--爬取知乎用户信息
听到“爬虫”,是不是第一时间想到Python/php ? 多少想玩爬虫的Java学习者就因为语言不通而止步.Java是真的不能做爬虫吗? 当然不是. 只不过python的3行代码能解决的问题,而Jav ...
- Knockout.Js官网学习(value绑定)
前言 value绑定是关联DOM元素的值到view model的属性上.主要是用在表单控件<input>,<select>和<textarea>上. 当用户编辑表单 ...
- .NET entityframework for mysql ,datetime字段存储值时有误差
昨天Tester发现数据有问题,大部分时间“datetime类型”都多了一秒,很少一部分数据的时间能完全对上(年月日时分秒),因为缺少关键日志,就各种排查,最后发现在调用Savechange方法前一刻 ...