P3859求助
  • 板块题目总版
  • 楼主cp152
  • 当前回复1
  • 已保存回复1
  • 发布时间2020/10/8 10:06
  • 上次更新2023/11/5 11:36:50
查看原帖
P3859求助
171544
cp152楼主2020/10/8 10:06

蒟蒻做的第一道紫题小偷,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。

2020/10/8 10:06
加载中...