题解 P3158 [CQOI2011]放棋子
题解
本题是一个 \(DP\) 加 容斥,容斥的式子很好推,重点是如何想到和如何推出 \(DP\) 部分的式子。
因为不同种颜色的棋子不能放在同一行或同一列,所以不同种的棋子是相对独立的。
据此,我们可以推出一个式子,设 \(f_{i,j,k}\) 表示前 \(k\) 种颜色占据了 \(i\) 行 \(j\) 列。
\]
其中 \(g_{i,j,k}\) 表示 \(k\) 个棋子占据 \(i\) 行 \(j\) 列,\(num_k\) 表示第 \(k\) 种颜色棋子的个数,后面的表示组合数。
来解释一下这个式子,其中因为 \(k-1\) 已经占据了 \(l\) 行 \(r\) 列,那么第 \(k\) 种颜色的棋子要占据 \(i-l\) 行 \(j-r\) 列。
所以这 \(num_k\) 颗棋子只能放在这 \(i-l\) 行 \(j-r\) 行的交汇处,所以由此我们可以得出 \(g\) 的式子
显然直接推不好推,所以我们要用容斥。易得 \(g_{i,j,k}\) 初始状态设为 \((^{i×j}_{num_k})\) ,但其中有一些情况无法占据所有的行列,所以
\]
最后,所有的行列不一定占据,但所有种类的棋子一定要放上,所以答案即为
\]
\(AC \kern 0.4emCODE:\)
#include<bits/stdc++.h>
#define ri register int
#define p(i) ++i
using namespace std;
namespace IO{
char buf[1<<21],*p1=buf,*p2=buf;
inline char gc() {return p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++;}
inline int read() {
ri x=0,f=1;char ch=gc();
while(ch<'0'||ch>'9') {if (ch=='-') f=-1;ch=gc();}
while(ch>='0'&&ch<='9') {x=(x<<1)+(x<<3)+(ch^48);ch=gc();}
return x*f;
}
}
using IO::read;
namespace nanfeng{
#define ll long long
static const int N=33;
static const int MOD=1e9+9;
static const int CN=12;
int C[N*N][N*N],g[N][N],f[N][N][CN],n,m,c;
inline int main() {
n=read(),m=read(),c=read();
const int S=n*m;
C[0][0]=f[0][0][0]=1;
for (ri i(1);i<=S;p(i)) {
C[i][0]=1;
for (ri j(1);j<=i;p(j)) C[i][j]=(C[i-1][j]+C[i-1][j-1])%MOD;
}
for (ri k(1);k<=c;p(k)) {
ri num=read();
memset(g,0,sizeof(g));
for (ri i(1);i<=n;p(i)) {
for (ri j(1);j<=m;p(j)) {
if (i*j<num) continue;//要加上优化,显然
g[i][j]=C[i*j][num];
for (ri l(1);l<=i;p(l)) {
for (ri r(1);r<=j;p(r)) {
if (l==i&&r==j) continue;
g[i][j]=((ll)g[i][j]-(ll)g[l][r]*C[i][l]%MOD*C[j][r]%MOD+MOD)%MOD;
// printf("g[%d][%d]=%d\n",i,j,g[i][j]);
}
}
}
}
for (ri i(1);i<=n;p(i)) {
for (ri j(1);j<=m;p(j)) {
for (ri l(0);l<i;p(l)) {
for (ri r(0);r<j;p(r)) {
if ((i-l)*(j-r)<num) break;
f[i][j][k]=((ll)f[i][j][k]+(ll)f[l][r][k-1]*g[i-l][j-r]%MOD*C[n-l][i-l]%MOD*C[m-r][j-r]%MOD)%MOD;
}
}
}
}
}
int ans=0;
for (ri i(1);i<=n;p(i)) {
for (ri j(1);j<=m;p(j)) ans=(ans+f[i][j][c])%MOD;
}
printf("%d\n",ans);
return 0;
}
}
int main() {return nanfeng::main();}
时间复杂度 \(O(n^2m^2c)\)
题解 P3158 [CQOI2011]放棋子的更多相关文章
- P3158 [CQOI2011]放棋子(dp+组合数)
P3158 [CQOI2011]放棋子 放棋子的顺序和方案数无关,所以可以从按颜色递推 设$f[u][p][k]$为放到第$u$种颜色,所剩空间$p*k$的方案数 $g[u][i][j]$表示第$u$ ...
- [洛谷P3158] [CQOI2011]放棋子
洛谷题目链接:[CQOI2011]放棋子 题目描述 在一个m行n列的棋盘里放一些彩色的棋子,使得每个格子最多放一个棋子,且不同 颜色的棋子不能在同一行或者同一列.有多少祌方法?例如,n=m=3,有两个 ...
- 洛谷P3158 [CQOI2011]放棋子 组合数学+DP
题意:在一个m行n列的棋盘里放一些彩色的棋子,使得每个格子最多放一个棋子,且不同颜色的棋子不能在同一行或者同一列.有多少祌方法? 解法:这道题不会做,太菜了qwq.题解是看洛谷大佬的. 设C是组合数, ...
- P3158 [CQOI2011]放棋子
传送门 题解(因为公式太多懒得自己抄写一遍了--) //minamoto #include<bits/stdc++.h> #define ll long long #define R re ...
- BZOJ 3294: [Cqoi2011]放棋子
3294: [Cqoi2011]放棋子 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 628 Solved: 238[Submit][Status] ...
- bzoj3294[Cqoi2011]放棋子 dp+组合+容斥
3294: [Cqoi2011]放棋子 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 755 Solved: 294[Submit][Status] ...
- [CQOI2011]放棋子 (DP,数论)
[CQOI2011]放棋子 \(solution:\) 看到这道题我们首先就应该想到有可能是DP和数论,因为题目已经很有特性了(首先题面是放棋子)(然后这一题方案数很多要取模)(而且这一题的数据范围很 ...
- bzoj千题计划261:bzoj3294: [Cqoi2011]放棋子
http://www.lydsy.com/JudgeOnline/problem.php?id=3294 如果一个颜色的棋子放在了第i行第j列,那这种颜色就会占据第i行第j列,其他颜色不能往这儿放 设 ...
- 【BZOJ 3294】 3294: [Cqoi2011]放棋子 (DP+组合数学+容斥原理)
3294: [Cqoi2011]放棋子 Description Input 输入第一行为两个整数n, m, c,即行数.列数和棋子的颜色数.第二行包含c个正整数,即每个颜色的棋子数.所有颜色的棋子总数 ...
随机推荐
- 为什么0x100是256个字节、0x400是1KB、0x800是2KB、0x1000是4KB?
[TOC] # 前言在刚开始学习嵌入式时我们就遇到各种进制之间的换算,十六进制.十进制.八进制.二进制等等,一开始会经常在各种进制之间迷失自我:在深入学习或者做项目或者工作时我们也经常要查看各种芯片的 ...
- kong配置service和route实现简单API代理
目录 通过konga连接kong实现API接口代理 1. ADD NEW SERVICE 2. ADD ROUTE 3. 验证API 代理 浏览器验证 请求kong api kong使用Admin A ...
- NTP配置(广播模式并且无认证)
1.服务器端 1.1服务器本地同步自己的时钟,否则无法对外提供NTP服务 [NTP]ntp refclock-master 3 [NTP]ntp refclock-master 127.127.1.1 ...
- java基础---数组的查找算法(2)
一.查找的基本概念 查找分为有序查找和无序查找,这里均以数组为对象,有序查找指的是数组元素有序排列,无序查找指的是数组元素有序或无序排列 平均查找长度(Average Search Length,AS ...
- Python使用笔记27--mysql操作封装类
1.面向过程 1 import pymysql 2 3 #面向过程 4 mysql_info = {'host':'127.0.0.1', 5 'port':3306, 6 'user':'root' ...
- C语言:char总结
char字符型数据1.用单引号限制的1字节的字符称为字符型数据,字符型常量2.字符型常量实质保存的是对应字符的ASCII码值,是一个整数3.字符型常量表示范围:0-2554.声明字符型变量 char ...
- 关于java异常处理的思考
学习java的过程中,初学者更多的是为了实验而写代码,而不考虑实际情况中的人机交互过程中的一些问题. 在java项目中,更多的用户不会因为你给了某些限制提醒,他就一定会按照你所给的提示来输入或者操作, ...
- 前端开发入门到进阶第三集【获取cookie然后单点登录后重定向】
/* var token ;//https://blog.csdn.net/qq_29207823/article/details/81745757 if( $.cookie('BBK_TOKEN') ...
- odoo12里面的RPC【远程过程调用】
odoo的RPC有两种:RPC API:1.xml-rpc 2.json-rpc 案例 x ...
- C++第三十三篇 -- 研究一下Windows驱动开发(一)内部构造介绍
因为工作原因,需要做一些与网卡有关的测试,其中涉及到了驱动这一块的知识,虽然程序可以运行,但是不搞清楚,心里总是不安,觉得没理解清楚.因此想看一下驱动开发.查了很多资料,看到有人推荐Windows驱动 ...