暗黑游戏(pgrune)

1.5k 词

题目描述

    暗黑游戏中,装备直接决定玩家人物的能力。可以使用Pg和Rune购买需要的物品。暗黑市场中的装备,每件有不同的价格(Pg和Rune)、能力值、最大可购买件数。Kid作为暗黑战网的一个玩家,当然希望使用尽可能少的Pg和Rune购买更优的装备,以获得最高的能力值。请你帮忙计算出现有支付能力下的最大可以获得的能力值。

输入

第一行,三个整数N,P,R,分别代表市场中物品种类,Pg的支付能力和Rune的支付能力。
第2..N+1行,每行四个整数,前两个整数分别为购买此物品需要花费的Pg,Rune,第三个整数若为0,则说明此物品可以购买无数件,若为其他数字,则为此物品可购买的最多件数(S),第四个整数为该装备的能力值。

输出

仅一行,一个整数,最大可获得的能力值。

样例输入

1
2
3
4
3 10 10
5 3 0 110
4 3 4 120
2 3 1 130

样例输出

1
370

提示

【样例解释】
选第二种装备2件和第三种装备1件。
【数据规模】
对于30%的数据, 0<N<=50, 0<P<=30, 0<R<=30, 0<=S<=8;
对于70%的数据, 0<N<=80, 0<P<=65, 0<R<=65, 0<=S<=16;
对于100%的数据, 0<N<=150, 0<P<=100, 0<R<=100, 0<=S<=32;

题解

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <iostream>
#include <cstring>
using namespace std;
int main() {
short n,p,r;
cin >> n >> p >> r;
int pg[n+1], rune[n+1], num[n+1], c[n+1], func[150][150];
for (int i = 1; i <= n; i++)
cin >> pg[i] >> rune[i] >> num[i] >> c[i];
memset(func, 0, sizeof(func));
for (int i = 1; i <= n; i++) {
if (num[i] == 0)
for (int j = pg[i]; j <= p; j++)
for (int k = rune[i]; k <= r; k++)
if (func[j][k] < func[j - pg[i]][k - rune[i]] + c[i])
func[j][k] = func[j - pg[i]][k - rune[i]] + c[i];
if (num[i] > 0)
for (int j = p; j >= 0; j--)
for (int k = r; k >= 0; k--)
for (int l = 1; l <= num[i]; l++) {
if (j - l * pg[i] < 0) break;
if (k - l * rune[i] < 0) break;
if (func[j][k] < func[j - l * pg[i]][k - l * rune[i]] + l * c[i]) func[j][k] = func[j - l * pg[i]][k - l * rune[i]] + l * c[i];
}
}
cout << func[p][r];
return 0;
}