[luogu] P1802 5倍经验日
题目详情
题目分析:这道题是标准的01背包,一开始没反应过来,这道题要开long long
,不然就只有90分,转移方程f[i]
代表使用i
个药剂瓶最多能得到多少经验值。一旦剩余的药剂瓶大于面对的敌人所需要使用的药剂瓶,就判断到底是认输经验值多,还是用药剂瓶打赢他的经验多。自己剩余的药剂瓶不够那直接认输,不然会浪费药剂瓶。
#include <cstdio>
#include <algorithm>
using namespace std;
int n, x, lose[1111], win[1111], use[1111];
long long f[1111];
int main()
{
scanf("%d%d", &n, &x);
for (int i = 1; i <= n; i++)
scanf("%d%d%d", &lose[i], &win[i], &use[i]);
for (int i = 1; i <= n; i++)
for (int j = x; j >= 0; j--)
{
if (j >= use[i])
f[j] = max(f[j] + lose[i], f[j - use[i]] + win[i]);
else
f[j] += lose[i];
}
printf("%lld", 5 * f[x]);
}