许诺 • 3天前
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std; struct Item {
int v, w;
}; int main() {
int n, W;
cin >> n >> W;
vector<Item> items;
for (int i = 0; i < n; ++i) {
int v, w, m;
cin >> v >> w >> m;
for (int k = 1; k <= m; k *= 2) {
items.push_back({k * v, k * w});
m -= k;
}
if (m > 0) {
items.push_back({m * v, m * w});
}
}
vector<int> dp(W + 1, 0);
for (const auto& item : items) {
for (int j = W; j >= item.w; --j) {
dp[j] = max(dp[j], dp[j - item.w] + item.v);
}
}
cout << dp[W] << endl;
return 0;
}
评论:
请先登录,才能进行评论