我随便找了一个题解交,结果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;
}