#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
int S, N;
cin >> S >> N;
vector<int> value(N), weight(N), quantity(N);
// Nhập thông tin các đồ vật
for (int i = 0; i < N; i++) {
cin >> value[i] >> weight[i] >> quantity[i];
}
vector<long long> dp(S + 1, 0); // dp[i] sẽ lưu giá trị lớn nhất có thể đạt được với trọng lượng i
for (int i = 0; i < N; i++) {
// Dùng cách "knapsack 0/1" mở rộng để xử lý số lượng đồ vật có thể chọn.
for (int j = S; j >= weight[i]; j--) {
for (int k = 1; k <= quantity[i] && k * weight[i] <= j; k++) {
dp[j] = max(dp[j], dp[j - k * weight[i]] + k * value[i]);
}
}
}
cout << dp[S] << endl;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |