이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
const int MAX_N=1e5, MAX_S=2000;
int s, n;
int v[MAX_N], w[MAX_N], k[MAX_N];
int dp[MAX_S+1];
unordered_map<int, int> used[MAX_S+1];
int main()
{
cin >> s >> n;
for(int i=0; i<n; i++){
cin >> v[i] >> w[i] >> k[i];
}
dp[0]=0;
for(int tot=1; tot<=s; tot++){
int max_value=dp[tot-1], max_item=(-1);
for(int i=0; i<n; i++){
if(tot-w[i]>=0 && (!used[tot-w[i]].count(i) || used[tot-w[i]][i]<k[i]) && dp[tot-w[i]]+v[i]>max_value){
max_value=dp[tot-w[i]]+v[i];
max_item=i;
}
}
dp[tot]=max_value;
if(max_item==(-1)){
used[tot]=used[tot-1];
}
else{
used[tot]=used[tot-w[max_item]];
used[tot][max_item]++;
}
}
cout << dp[s];
}
# | 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... |