P3158 [CQOI2011]放棋子(dp+组合数)
放棋子的顺序和方案数无关,所以可以从按颜色递推
设$f[u][p][k]$为放到第$u$种颜色,所剩空间$p*k$的方案数
$g[u][i][j]$表示第$u$种颜色占据$i*j$空间的方案数,可以预处理
$g[u][i][j]=\binom{i*j}{c[u]}-\sum_{p=1}^{i}\sum_{k=1}^{j}g[u][p][k]*\binom{i}{i-p}*\binom{j}{j-k}*[p<i||j<k]$
$f[u][p][k]=\sum_{i=1}^{n-p}\sum_{j=1}^{m-k}f[u-1][p+i][k+j]*\binom{p+i}{i}*\binom{k+j}{j}*g[u][i][j]$
复杂度$O(n^2m^2C)$
#include<iostream>
#include<cstdio>
#include<cstring>
#define ri register int
using namespace std;
const int P=;
int t,n,m,s,C[][],g[][][],f[][][],ans;
int main(){
scanf("%d%d%d",&n,&m,&t);
for(ri i=;i<=n*m;++i){
C[i][]=;
for(int j=;j<=i;++j) C[i][j]=(C[i-][j]+C[i-][j-])%P;
}f[][n][m]=;
for(ri u=;u<=t;++u){
scanf("%d",&s);
for(ri i=;i<=n;++i)
for(ri j=;j<=m;++j) if(s<=i*j){
g[u][i][j]=C[i*j][s];
for(ri p=;p<=i;++p)
for(ri k=;k<=j;++k) if(p<i||k<j){
ri v=1ll*C[i][i-p]*C[j][j-k]%P;
(g[u][i][j]-=1ll*g[u][p][k]*v%P-P)%=P;
}
}
for(ri i=;i<=n;++i)
for(ri j=;j<=m;++j)
if(s<=i*j)
for(ri p=i;p<=n;++p)
for(ri k=j;k<=m;++k){
ri v=1ll*C[p][i]*C[k][j]%P*g[u][i][j]%P;
(f[u][p-i][k-j]+=1ll*f[u-][p][k]*v%P)%=P;
}
}
for(ri i=;i<=n;++i)
for(ri j=;j<=m;++j)
(ans+=f[t][i][j])%=P;
printf("%d",ans);
return ;
}
P3158 [CQOI2011]放棋子(dp+组合数)的更多相关文章
- bzoj3294[Cqoi2011]放棋子 dp+组合+容斥
3294: [Cqoi2011]放棋子 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 755 Solved: 294[Submit][Status] ...
- [洛谷P3158] [CQOI2011]放棋子
洛谷题目链接:[CQOI2011]放棋子 题目描述 在一个m行n列的棋盘里放一些彩色的棋子,使得每个格子最多放一个棋子,且不同 颜色的棋子不能在同一行或者同一列.有多少祌方法?例如,n=m=3,有两个 ...
- [CQOI2011]放棋子--DP
题目描述: 输入格式 输入第一行为两个整数n, m, c,即行数.列数和棋子的颜色数.第二行包含c个正整数,即每个颜色的棋子数.所有颜色的棋子总数保证不超过nm.N,M<=30 C<=10 ...
- 洛谷P3158 [CQOI2011]放棋子 组合数学+DP
题意:在一个m行n列的棋盘里放一些彩色的棋子,使得每个格子最多放一个棋子,且不同颜色的棋子不能在同一行或者同一列.有多少祌方法? 解法:这道题不会做,太菜了qwq.题解是看洛谷大佬的. 设C是组合数, ...
- 【BZOJ3294/洛谷3158】[CQOI2011]放棋子(组合数+DP)
题目: 洛谷3158 分析: 某OIer兔崽子的此题代码中的三个函数名:dfs.ddfs.dddfs(充满毒瘤的气息 显然,行与行之间.列与列之间是互相独立的.考虑背包,用\(f[k][i][j]\) ...
- 题解 P3158 [CQOI2011]放棋子
题解 本题是一个 \(DP\) 加 容斥,容斥的式子很好推,重点是如何想到和如何推出 \(DP\) 部分的式子. 因为不同种颜色的棋子不能放在同一行或同一列,所以不同种的棋子是相对独立的. 据此,我们 ...
- P3158 [CQOI2011]放棋子
传送门 题解(因为公式太多懒得自己抄写一遍了--) //minamoto #include<bits/stdc++.h> #define ll long long #define R re ...
- 【BZOJ 3294】 3294: [Cqoi2011]放棋子 (DP+组合数学+容斥原理)
3294: [Cqoi2011]放棋子 Description Input 输入第一行为两个整数n, m, c,即行数.列数和棋子的颜色数.第二行包含c个正整数,即每个颜色的棋子数.所有颜色的棋子总数 ...
- [CQOI2011]放棋子 (DP,数论)
[CQOI2011]放棋子 \(solution:\) 看到这道题我们首先就应该想到有可能是DP和数论,因为题目已经很有特性了(首先题面是放棋子)(然后这一题方案数很多要取模)(而且这一题的数据范围很 ...
随机推荐
- springboot 集成apollo,根据不同环境加载配置
- PCL智能指针疑云 <二> 使用同一智能指针作为PCL预处理API的输入和输出
问题介绍: slam构建地图,先进行降采样,再进行可视化或存储.然而经过降采样后,代码没有报错的情况下,点云数据散成一团.将代码和点云数据展示如下, pcl::VoxelGrid<Lidar:: ...
- C# walls
在学习C#的阶段中,我们一点一点的往前爬, 此代码需要添加selenium ,和 获取 引用. using Ivony.Html.Parser; using Ivony.Html; using Ope ...
- 3-Gitblit服务器搭建及IDEA整合Git使用
背景:虽然有GitHub.GitLab这样强大的Git仓库,但是涉及私有Git库要收费,所以自己动手搭建免费的用用 环境:windows 7 旗舰版.JDK 1.8.IDEA 2017 ------- ...
- git回滚操作
一,找到之前的版本历史纪录,确定要回滚到那个版本号:git log 二,回滚到这个版本:git reset --hard 72229f823c8b21cbe52142a944d74f1883fa41a ...
- Vue创建局部组件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 送书福利| Python 完全自学手册
前言 这里不讨论「能不能学,要不要学,应不应该学 Python」的问题,这里只会告诉你怎么学. 首先需要强调的是,如果 Python 都学不会,那么我建议你考虑别的行业,因为 Python 之简单,令 ...
- 阶段3 1.Mybatis_04.自定义Mybatis框架基于注解开发_1 今日课程内容介绍
- c# 排列组合代码类
/// <summary> /// 排列组件算法类 /// </summary> /// <typeparam name="T"></ty ...
- Struts2框架学习笔记1
1,框架概述 1.1,什么是框架(了解) 将一些重复性的代码进行封装,简化程序员的编程操作,可以使得程序员在编码中把更多的精力放到业务需求的分析和理解上面,相当于一个半成品软件. 1.2,三大框架(掌 ...