题目大意:超市甩卖。有n件商品,每件商品有对应的价值和重量。有一个家族准备去超市买东西,每个人最多每种甩卖商品只能买一件,可以拿很多不同的商品但是要能拿得动。给出每个人能拿得动的最大重量,问这样的一个家族取采购能够得到的最大的价值。
解题思路:01背包。 dp【j】 = Max (dp【j】, dp【j - W】 + P);W是商品的重量,P是商品的价值。
代码:
#include <cstdio> #include <cstring> const int N = 10005; const int maxn = 35; int dp[maxn]; int object[N][2]; int Max (const int a, const int b) { return a > b ? a: b; } int main () { int t; int n, g; int w; int ans; scanf ("%d", &t); while (t--) { scanf ("%d", &n); for (int i = 0; i < n; i++) scanf ("%d%d", &object[i][0], &object[i][1]); scanf ("%d", &g); memset (dp, 0, sizeof (dp)); for (int i = 0; i < n; i++) for (int j = maxn - 5; j >= object[i][1]; j--) dp[j] = Max(dp[j], dp[j - object[i][1]] + object[i][0]); ans = 0; for (int i = 0; i < g; i++) { scanf ("%d", &w); ans += dp[w]; } printf ("%d\n", ans); } return 0; }
uva10130 - SuperSale(01背包),布布扣,bubuko.com
原文:http://blog.csdn.net/u012997373/article/details/38360465