【bzoj1270】[BeijingWc2008]雷涛的小猫 dp

题目描述

 

输入

输出

样例输入

样例输出

8


题解

dp

设f[i][j]表示在第i棵树的j高度时最多吃到的柿子数。

那么只有两种可能能够到达这个位置:滑下来、跳下来。

滑下来直接用f[i][j+1]转移,跳下来需要在dp同时记录一个g数组,g[j]表示j高度时最多的柿子数,这样可以用g[j+D]转移。

然后跑dp即可。

#include <cstdio>
#include <algorithm>
#define N 2010
using namespace std;
int f[N][N] , num[N][N] , g[N];
inline int read()
{
	int ret = 0; char ch = getchar();
	while(ch < '0' || ch > '9') ch = getchar();
	while(ch >= '0' && ch <= '9') ret = (ret << 3) + (ret << 1) + ch - '0' , ch = getchar();
	return ret;
}
int main()
{
	int n , m , d , k , i , j;
	n = read() , m = read() , d = read();
	for(i = 1 ; i <= n ; i ++ )
	{
		k = read();
		while(k -- ) num[i][read()] ++ ;
	}
	for(j = m ; ~j ; j -- )
	{
		for(i = 1 ; i <= n ; i ++ )
		{
			f[i][j] = f[i][j + 1] + num[i][j];
			if(j + d <= m) f[i][j] = max(f[i][j] , g[j + d] + num[i][j]);
			g[j] = max(g[j] , f[i][j]);
		}
	}
	printf("%d\n" , g[0]);
	return 0;
}

 

posted @ 2017-05-15 21:00  GXZlegend  阅读(227)  评论(0编辑  收藏  举报