蒟蒻做的第一道紫题小偷,wa了一个点,求助。
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
struct ABC{
int x,y,z;
}b[10005];
int n,m,ans[1005][10005];
int a[505];
bool com(ABC a,ABC b)
{
return a.x>b.x;
}
int main()
{
// freopen("","r",stdin);
// freopen("","w",stdout);
scanf("%d%d",&n,&m);
a[0]=2e9;
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
if(i>=2)
a[i]=min(a[i-1],a[i]);
}
for(int i=1;i<=m;i++)
{
scanf("%d%d%d",&b[i].x,&b[i].y,&b[i].z);
b[i].x++;
}
sort(b+1,b+m+1,com);
for(int i=1;i<=m;i++)
{
for(int j=1;j<a[b[i].x];j++)
{
ans[i][j]=max(ans[i-1][j],ans[i][j-1]);
if(j>=b[i].z)
{
ans[i][j]=max(ans[i][j],ans[i][j-b[i].z]+b[i].y);
}
}
}
cout<<ans[m][a[1]-1];
return 0;
}
用背包问题的模板代码改的,也不知道为什么会wa。