bzoj 2302: [HAOI2011]Problem c
Description
Input
第一行一个整数T,表示数据组数
对于每组数据,第一行有三个整数,分别表示n、m、M
若m不为0,则接下来一行有m对整数,p1、q1,p2、q2 ,…, pm、qm,其中第i对整数pi、qi表示第pi个人的编号必须为qi
Output
对于每组数据输出一行,若是有解则输出YES,后跟一个整数表示方案数mod M,注意,YES和数之间只有一个空格,否则输出NO
Sample Input
4 3 10
1 2 2 1 3 1
10 3 8882
7 9 2 9 5 10
Sample Output
YES 4
HINT
100%的数据满足:1≤T≤10,1≤n≤300,0≤m≤n,2≤M≤109,1≤pi、qi≤n 且保证pi互不相同。
Source
这题的状态简直是妙不可言;
我们考虑不合法的情况,我们记编号>=i的数量为s[i],那么只要s[i]>n-i+1就不合法;
那么我们问题可以简化为对于任意的i,都有编号>=i的人数<=i;然后就可以进行dp了;
我们设f[i][j]表示已经填了前i个编号,标号小于等于i的有j个的方案数;
然后记cnt[i],为编号必须为i的数量,sum[i]表示编号可以<=i的数量;
转移方程为 f[i][j]=∑f[i-1][j-k]*C*(sum[i]-(j-k)-cnt[i],k-cnt[i]);
其中k为这次选择编号为<=i的数量,那么这次能够自由选择的数量为sum[i]-(j-k)-cnt[i],(其中sum[i]为总共的,(j-k)为之前有的,cnt[i]为已经固定的)
注意在转移的时候要保证j>=i,否则是不合法的;
- //MADE BY QT666
- #include<iostream>
- #include<cstdio>
- #include<algorithm>
- #include<cstring>
- using namespace std;
- typedef long long ll;
- const int N=1050;
- int cnt[N],sum[N],mod,n,m;
- ll c[N][N],f[N][N];
- int main(){
- int T;scanf("%d",&T);
- while(T--){
- int flg=0;
- scanf("%d%d%d",&n,&m,&mod);
- memset(cnt,0,sizeof(cnt));
- memset(sum,0,sizeof(sum));
- memset(c,0,sizeof(c));
- memset(f,0,sizeof(f));
- for(int i=1;i<=m;i++){
- int p,q;scanf("%d%d",&p,&q);cnt[q]++;
- }
- sum[0]=n-m;
- for(int i=1;i<=n;i++){
- sum[i]=sum[i-1]+cnt[i];
- if(sum[i]<i) {puts("NO"),flg=1;break;}
- }
- if(flg) continue;
- else{
- for(int i=0;i<=n;++i) c[i][0]=1;
- for(int i=1;i<=n;++i)
- for(int j=1;j<=i;++j){
- c[i][j]=(c[i-1][j-1]+c[i-1][j])%mod;
- }
- }
- f[0][0]=1;
- for(int i=1;i<=n;i++){
- for(int j=i;j<=sum[i];j++){
- for(int k=cnt[i];k<=j-i+1;k++){
- (f[i][j]+=(f[i-1][j-k]*c[sum[i]-(j-k)-cnt[i]][k-cnt[i]])%mod)%=mod;
- }
- }
- }
- cout<<"YES ";printf("%lld\n",f[n][n]);
- }
- return 0;
- }
bzoj 2302: [HAOI2011]Problem c的更多相关文章
- BZOJ 2302: [HAOI2011]Problem c( dp )
dp(i, j)表示从i~N中为j个人选定的方案数, 状态转移就考虑选多少人为i编号, 然后从i+1的方案数算过来就可以了. 时间复杂度O(TN^2) ------------------------ ...
- BZOJ 2302: [HAOI2011]Problem c [DP 组合计数]
2302: [HAOI2011]Problem c Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 648 Solved: 355[Submit][S ...
- BZOJ 2302: [HAOI2011]Problem c(数学+DP)
题面: bzoj_2302 题解: 令\(dp[i][j]\)表示编号 \(\leq i\)的人有j个的方案数: \(cnt[i]\)表示编号指定为\(i\)的人数,\(sum[i]\)表示编号可以\ ...
- Bzoj 2301: [HAOI2011]Problem b(莫比乌斯反演+除法分块)
2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MB Description 对于给出的n个询问,每次求有多少个数对(x, ...
- bzoj 2301: [HAOI2011]Problem b
2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MB Submit: 3757 Solved: 1671 [Submit] ...
- BZOJ 2298: [HAOI2011]problem a 动态规划
2298: [HAOI2011]problem a Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnli ...
- BZOJ 2301: [HAOI2011]Problem b 莫比乌斯反演
2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MBSubmit: 1007 Solved: 415[Submit][ ...
- BZOJ 2301: [HAOI2011]Problem b( 数论 )
和POI某道题是一样的... http://www.cnblogs.com/JSZX11556/p/4686674.html 只需要二维差分一下就行了. 时间复杂度O(MAXN + N^1.5) - ...
- BZOJ 2301 [HAOI2011]Problem b (分块 + 莫比乌斯反演)
2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MBSubmit: 6519 Solved: 3026[Submit] ...
随机推荐
- Ubuntu下编译Bilibili/ijkplayer
在做Android客户端视频播放器的过程中熟悉ijkplayer.他在视频支持协议上要比Android原生的mediaplayer做的要好.因此,自己也基于Bilibili/ijkplayer的重新编 ...
- [flask 优化] 由flask-bootstrap,flask-moment引起的访问速度慢的原因及解决办法
一周时间快速阅读了400页的<javascript基础教程>,理解了主要概念.虽然对jquery.ajax.json这些方法的运用还不熟练,但在理清了概念之后解决了一个很久之前的疑问. 我 ...
- Nomad入门
Nomad 简介 Nomad是一个管理机器集群并在集群上运行应用程序的工具. Nomad的特点: 支持docker,Nomad的job可以使用docker驱动将应用部署到集群中. Nomad安装在li ...
- ThinkPHP中处理模板引擎的volist标签
Volist标签主要用于在模板中循环输出数据集或者多维数组 必须得属性有:name属性,要输出的数据模板变量,id是循环变量. 其他属性参见开发手册. 通常模型的select方法返回的结果是一个二维数 ...
- powershell 监控, 重启网卡
#powershell 监控, 重启网卡 一台Windows服务器,由于负荷较大,偶尔会网络中断,就写了个powershell脚本,监控ip是否通,不通就重启网卡 cls $host.UI.RawUI ...
- KD-tree详解
转载自:http://blog.csdn.NET/zhjchengfeng5/article/details/7855241 首先来一个问题: 给定平面上一个点集 E ,还有一个定点 V ,怎么在一群 ...
- iOS 处理socket粘包问题
1.什么是粘包? 粘包通常出现在TCP的协议里面,对于UDP来说是不会出现粘包状况的,之所以出现这种状况的原因,涉及到一种名为Nagle的算法. Nagle算法通过减少必须发送的封包的数量,提高网络应 ...
- Python3实现简单可学习的手写体识别
0.目录 1.前言 2.通过pymssql与数据库的交互 3.通过pyqt与界面的交互 4.UI与数据库的交互 5.最后的main主函数 1.前言 版本:Python3.6.1 + PyQt5 + S ...
- [C#]使用IFormattable接口来实现字符串格式化
本文为原创文章.源代码为原创代码,如转载/复制,请在网页/代码处明显位置标明原文名称.作者及网址,谢谢! 开发工具:VS2017 语言:C# DotNet版本:.Net FrameWork 4.0及以 ...
- PHP 数据库连接池实现
摘要 xml 读取配置文件 简易方式 常规方式 PHP解析XML 配置文件 解析 数据库连接池 測试 申请过多时拒绝请求 已满后拒绝放入 总结 摘要 之前总是以脚本面向过程的方式写PHP代码,所以非常 ...