当前位置 : 主页 > 编程语言 > java >

排队问题

来源:互联网 收集:自由互联 发布时间:2022-09-02
一道学校内部测试赛的题目,对于这题我们采用的方法是DP。 dp[i][j][0~1]表示有i个男生j个女生时,最后一个人站的是男生(1)或女生(0)的方法数。 在男生个数没有超过k1的时候:dp[i][j][


排队问题_i++

排队问题_i++

一道学校内部测试赛的题目,对于这题我们采用的方法是DP。

dp[i][j][0~1]表示有i个男生j个女生时,最后一个人站的是男生(1)或女生(0)的方法数。

在男生个数没有超过k1的时候:dp[i][j][0] = dp[i-1][j][0] + dp[i-1][j][1]。

在女生个数没有超过k2的时候:dp[i][j][1] = dp[i][j-1][0] + dp[i][j-1][1]。

在男生个数超过k1的时候:dp[i][j][0] = dp[i-1][j][0] + dp[i-1][j][1] - dp[i-k1-1][j][0]。(相当于减去从第j+i-k1位开始之后都是男生的连续k1和男生的情况)

在女生个数超过k2的时候:dp[i][j][1] = dp[i][j-1][1] + dp[i][j-1][0] - dp[i][j-k2-1][1]。(同上)


#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 100+5;
const int MOD = 1e8;
int dp[maxn][maxn][2];
int x,y,k1,k2;
int main()
{
while(scanf("%d%d%d%d", &x,&y,&k1,&k2) !=EOF)
{
memset(dp,0,sizeof(dp));
int i,j;
for(i=1; i<=k1; i++) dp[i][0][1] = 1;
for(j=1; j<=k2; j++) dp[0][j][0] = 1;
for(i=1; i<=k1 && i<=x; i++)
{
for(j=1; j<=k2 && j<=y; j++)
{
dp[i][j][0] = (dp[i][j-1][1] + dp[i][j-1][0])%MOD;
dp[i][j][1] = (dp[i-1][j][1] + dp[i-1][j][0])%MOD;
}
for( ; j<=y; j++)
{
dp[i][j][0] = (dp[i][j-1][1] + dp[i][j-1][0] - dp[i][j-k2-1][1]+MOD)%MOD;
dp[i][j][1] = (dp[i-1][j][1] + dp[i-1][j][0])%MOD;
}
}
for( ; i<=x; i++)
{
for(j=1; j<=k2 && j<=y; j++)
{
dp[i][j][0] = (dp[i][j-1][1] + dp[i][j-1][0])%MOD;
dp[i][j][1] = (dp[i-1][j][1] + dp[i-1][j][0] - dp[i-k1-1][j][0]+MOD)%MOD;
}
for( ; j<=y; j++)
{
dp[i][j][0] = (dp[i][j-1][1] + dp[i][j-1][0] - dp[i][j-k2-1][1]+MOD)%MOD;
dp[i][j][1] = (dp[i-1][j][1] + dp[i-1][j][0] - dp[i-k1-1][j][0]+MOD)%MOD;
}
}
printf("%d\n", (dp[x][y][1]+dp[x][y][0])%MOD);
}
}



上一篇:TOJ 3991 Eat or Study
下一篇:没有了
网友评论