大家注意,题解有误!!!
查看原帖
大家注意,题解有误!!!
266566
Borscht楼主2020/8/25 08:33

我随便找了一个题解交,结果RE一个点WA了三个点!!!

是第八个题解!!!

#include<bits/stdc++.h>
using namespace std;
int n,h,delta;
int a[2050][2050],f[2050][2050];
int maxh[2050];
int main(){
	scanf("%d%d%d",&n,&h,&delta);
	for(int i=1;i<=n;i++){
		int x;
		scanf("%d",&x);
		for(int j=1;j<=x;j++){
			int p;
			scanf("%d",&p);
			a[p][i]++;
		}
	}
	for(int i=1;i<=h;i++){
		for(int j=1;j<=n;j++){
			if(i>1)f[i][j]=f[i-1][j];//防止数组越界特判了一下
			if(i>delta)f[i][j]=max(f[i][j],maxh[i-delta]);//同理
			f[i][j]+=a[i][j];
			maxh[i]=max(maxh[i],f[i][j]);
		}
	}
	printf("%d",maxh[h]);
	return 0;
}
2020/8/25 08:33
加载中...