BZOJ 2302: [HAOI2011]Problem c( dp )

时间:2023-02-17 12:38:48

BZOJ 2302: [HAOI2011]Problem c( dp )

dp(i, j)表示从i~N中为j个人选定的方案数, 状态转移就考虑选多少人为i编号, 然后从i+1的方案数算过来就可以了. 时间复杂度O(TN^2)

---------------------------------------------------------------------

#include<cstdio>
#include<algorithm>
#include<cstring>
 
using namespace std;
 
typedef long long ll;
#define c(i) (cnt[i] - cnt[i + 1])
 
const int maxn = 309;
const int maxT = 11;
 
int dp[maxn][maxn], N, cnt[maxn];
int V[maxn][maxn], Comb[maxT][maxn][maxn];
int n[maxT], m[maxT], P[maxT], q[maxT][maxn], T, _T;
 
inline void upd(int &x, int t) {
if((x += t) >= P[_T])
x -= P[_T];
}
 
void Init() {
for(_T = 0; _T < T; _T++) {
Comb[_T][0][0] = 1;
for(int i = 1; i <= n[_T]; i++) {
Comb[_T][i][0] = 1;
for(int j = 1; j <= i; j++) {
Comb[_T][i][j] = Comb[_T][i - 1][j - 1] + Comb[_T][i - 1][j];
if(Comb[_T][i][j] >= P[_T])
Comb[_T][i][j] -= P[_T];
}
}
}
}
 
void Read() {
scanf("%d%d%d", n + _T, m + _T, P + _T);
for(int i = 0, p; i < m[_T]; i++)
scanf("%d%d", &p, q[_T] + i);
}
 
inline int C(int n, int m) {
if(n < m)
return 0;
return Comb[_T][n][m];
}
 
void Work() {
N = n[_T];
memset(cnt, 0, sizeof cnt);
for(int i = 0; i < m[_T]; i++)
cnt[q[_T][i]]++;
for(int i = N; i; i--)
if((cnt[i] += cnt[i + 1]) > N - i + 1) {
puts("NO");
return;
}
memset(dp, 0, sizeof dp);
if(cnt[N]) {
dp[N][0] = 0;
dp[N][1] = 1;
} else {
dp[N][0] = 1;
dp[N][1] = N - cnt[1];
}
for(int i = N; --i; ) {
for(int j = N - i + 1; j >= cnt[i]; j--)
for(int k = c(i); k <= j; k++)
upd(dp[i][j], ll(dp[i + 1][j - k]) * C(N - j + k - cnt[1] + cnt[i + 1], k - c(i)) % P[_T]);
}
printf("YES %d\n", dp[1][N]);
}
 
int main() {
scanf("%d", &T);
for(_T = 0; _T < T; _T++) Read();
Init();
for(_T = 0; _T < T; _T++) Work();
return 0;
}

---------------------------------------------------------------------

2302: [HAOI2011]Problem c

Time Limit: 30 Sec  Memory Limit: 256 MB
Submit: 407  Solved: 221
[Submit][Status][Discuss]

Description

给n个人安排座位,先给每个人一个1~n的编号,设第i个人的编号为ai(不同人的编号可以相同),接着从第一个人开始,大家依次入座,第i个人来了以后尝试坐到ai,如果ai被占据了,就尝试ai+1,ai+1也被占据了的话就尝试ai+2,……,如果一直尝试到第n个都不行,该安排方案就不合法。然而有m个人的编号已经确定(他们或许贿赂了你的上司...),你只能安排剩下的人的编号,求有多少种合法的安排方案。由于答案可能很大,只需输出其除以M后的余数即可。

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

2

4 3 10

1 2 2 1 3 1

10 3 8882

7 9 2 9 5 10

Sample Output

YES 4

NO

HINT

100%的数据满足:1≤T≤10,1≤n≤300,0≤m≤n,2≤M≤109,1≤pi、qi≤n   且保证pi互不相同。

Source

BZOJ 2302: [HAOI2011]Problem c( dp )的更多相关文章

  1. BZOJ 2302&colon; &lbrack;HAOI2011&rsqb;Problem c &lbrack;DP 组合计数&rsqb;

    2302: [HAOI2011]Problem c Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 648  Solved: 355[Submit][S ...

  2. BZOJ 2302&colon; &lbrack;HAOI2011&rsqb;Problem c(数学&plus;DP)

    题面: bzoj_2302 题解: 令\(dp[i][j]\)表示编号 \(\leq i\)的人有j个的方案数: \(cnt[i]\)表示编号指定为\(i\)的人数,\(sum[i]\)表示编号可以\ ...

  3. bzoj 2302&colon; &lbrack;HAOI2011&rsqb;Problem c

    Description 给n个人安排座位,先给每个人一个1~n的编号,设第i个人的编号为ai(不同人的编号可以相同),接着从第一个人开始,大家依次入座,第i个人来了以后尝试坐到ai,如果ai被占据了, ...

  4. BZOJ 2298&colon; &lbrack;HAOI2011&rsqb;problem a 动态规划

    2298: [HAOI2011]problem a Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnli ...

  5. Bzoj 2301&colon; &lbrack;HAOI2011&rsqb;Problem b&lpar;莫比乌斯反演&plus;除法分块&rpar;

    2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MB Description 对于给出的n个询问,每次求有多少个数对(x, ...

  6. bzoj 2301&colon; &lbrack;HAOI2011&rsqb;Problem b

    2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MB Submit: 3757 Solved: 1671 [Submit] ...

  7. BZOJ 2301&colon; &lbrack;HAOI2011&rsqb;Problem b 莫比乌斯反演

    2301: [HAOI2011]Problem b Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 1007  Solved: 415[Submit][ ...

  8. BZOJ 2301&colon; &lbrack;HAOI2011&rsqb;Problem b&lpar; 数论 &rpar;

    和POI某道题是一样的...  http://www.cnblogs.com/JSZX11556/p/4686674.html 只需要二维差分一下就行了. 时间复杂度O(MAXN + N^1.5) - ...

  9. BZOJ 2301 &lbrack;HAOI2011&rsqb;Problem b &lpar;分块 &plus; 莫比乌斯反演&rpar;

    2301: [HAOI2011]Problem b Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 6519  Solved: 3026[Submit] ...

随机推荐

  1. Unity Standard Assets 简介之 Utility

    决定写这个系列起因于刚才的偶然所见,我发现当前版本的Unity有一个 Utility 标准资源包,里面有一个 FPSCounter 脚本提供了显示游戏运行帧率的基本功能,而我几周前刚刚写过一个同样功能 ...

  2. LightOJ 1047-Program C

    Description The people of Mohammadpur have decided to paint each of their houses red, green, or blue ...

  3. BDB &lpar;Berkeley DB&rpar;简要数据库(转载)

    使用最近DBD.然后搜了下相关资料,首先公布的是一门科学: 转会http://www.javaeye.com/topic/202990 DB综述DB最初开发的目的是以新的HASH訪问算法来取代旧的hs ...

  4. Cells Not Under Attack

    Cells Not Under Attack Vasya has the square chessboard of size n × n and m rooks. Initially the ches ...

  5. php中&lpar;包括织梦cms&rpar;set&lowbar;time&lowbar;limit&lpar;0&rpar;不起作用的解决方法

    背景介绍: 在做织梦冗余图片清理的功能时, 由于冗余图片太多,导致每次清理时都会超时, 后来在网上搜索了各种文章,网上有如下的解决方法: set_time_limit(0) ini_set('max_ ...

  6. VLC 用到的那些 YUV 格式

    YUV是视频应用中使用的一类像素格式.YUV实际上是所有“YUV”像素格式共有的颜色空间的名称. 与RGB格式(红 - 绿 - 蓝)相对应,YUV颜色用一个称为Y(相当于灰度)的“亮度”分量和两个“色 ...

  7. flask框架----flask中的wtforms使用

    一.简单介绍flask中的wtforms WTForms是一个支持多个web框架的form组件,主要用于对用户请求数据进行验证. 安装: pip3 install wtforms 二.简单使用wtfo ...

  8. Theano笔记

    scan函数 theano.scan(fn, sequences=None, outputs_info=None,non_sequences=None, n_steps=None, truncate_ ...

  9. python&colon; 面向对象&colon;类和对象调用类中的变量和方法

    一. 面向对象初识 我们在生活中做事都是面向过程的,前面实现一些基本逻辑功能代码也是用面向过程的语句实现的,后来学了函数,把这些功能又装到了函数里.但用面向过程的方法去写程序,只能实现一个功能,我们要 ...

  10. 水池问题的lua语言算法(面试题分析:我的Twitter技术面试失败了)

    twitter面试题内容 “看下面这个图片” “在这个图片里我们有不同高度的墙.这个图片由一个整数数组所代表,数组中每个数是墙的高度.上边的图可以表示为数组[2,5,1,2,3,4,7,7,6]” “ ...