题目描述
暗黑游戏中,装备直接决定玩家人物的能力。可以使用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
|
样例输出
提示
【样例解释】
选第二种装备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; }
|