//    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的更多相关文章

  1. UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举)

    UVA.11806 Cheerleaders (组合数学 容斥原理 二进制枚举) 题意分析 给出n*m的矩形格子,给出k个点,每个格子里面可以放一个点.现在要求格子的最外围一圈的每行每列,至少要放一个 ...

  2. UVA 11806 Cheerleaders dp+容斥

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

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

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

  4. uva 11806 Cheerleaders (容斥)

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

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

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

  6. UVA 11806 Cheerleaders (容斥原理)

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

  7. UVA 11806 Cheerleaders (容斥原理

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

  8. 【递推】【组合数】【容斥原理】UVA - 11806 - Cheerleaders

    http://www.cnblogs.com/khbcsu/p/4245943.html 本题如果直接枚举的话难度很大并且会无从下手.那么我们是否可以采取逆向思考的方法来解决问题呢?我们可以用总的情况 ...

  9. UVa 11806 - Cheerleaders (组合计数+容斥原理)

    <训练指南>p.108 #include <cstdio> #include <cstring> #include <cstdlib> using na ...

随机推荐

  1. Java 如何跳出多重嵌套循环体?

    1. 在最外层循环语句前定义一个标号,循环体内任意位置都可以使用带有标号的break语句跳出外层循环,结束整个循环. System.out.println("MainClass1 Start ...

  2. Hibernate SQL查询 addScalar()或addEntity()

    本文完全引用自: http://www.cnblogs.com/chenyixue/p/5601285.html Hibernate除了支持HQL查询外,还支持原生SQL查询.          对原 ...

  3. php js 排序

     编写背景及排序 规则 公司需要对游戏进行一系列的排序,在这里只说我自己遇到问题的哪一段 //规则:$plat数据要根据$sort里的sort为相应 可以输入一个数字,即为该平台: 解决思路:将$so ...

  4. SQL Server 获取最后一天(指定时间的月最后一天日期)

    /* author OceanHo @ 2015-10-23 10:14:21 获取指定时间字符串指定日期的月最后一天日期 */ IF OBJECT_ID('get_LastDayDate') IS ...

  5. sql 将查询结果为多行一列合并为一行一列

    使用sql stuff函数 /*         stuff(param1, startIndex, length, param2)说明:将param1中自startIndex(SQL中都是从1开始, ...

  6. loadView、viewDidLoad、viewWillAppear、viewDidAppear等详解

    loadView; This is where subclasses should create their custom view hierarchy if they aren't using a ...

  7. 一个简单的makefile

    #common makefile header LOCAL_INCLUDE := \ -I/xxx/ACE/ACE/ LOCAL_FLAGS := $(LOCAL_INCLUDE) LIBS := - ...

  8. Java实现中文数字转换为阿拉伯数字

    /** * 中文數字转阿拉伯数组[十万九千零六十 --> 109060] * @author 雪见烟寒 * @param chineseNumber * @return */ @Suppress ...

  9. 几个开源XMPP Android客户端简单比较

      想做个基于xmpp的即时通讯工具,服务端已经基本成型了.当然需要客户端需要配合,PC端基于spark进行改造,手机端先从Android入手(IOS估计一个人是搞不过来了). 原本Android开发 ...

  10. 通过viewmodel找到view

    如何通过viewmodel找到view? 之前的做法是,在view加载时(Loaded),将view保存到viewmodel中,后来想想Caliburn-Micro,自带方法可以通过viewmodel ...