[luogu] P1802 5倍经验日

[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]);
}
发布了7 篇原创文章 · 获赞 0 · 访问量 67

猜你喜欢

转载自blog.csdn.net/weixin_45646006/article/details/105027796