This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
int main(){
//ios::sync_with_stdio(false);
//cin.tie(0);
int limit,goods_num;
cin >> limit >> goods_num;
map<int,vector<pair<int,int>>> by_weight;
for(int i=0;i<goods_num;i++){
int value,weight,num;
cin >> value >> weight >> num;
if(value<=limit && num>0){
by_weight[weight].push_back({value,num});
}
}
vector<vector<int>> dp(by_weight.size()+1,vector<int>(limit+1,INT_MIN));
dp[0][0]=0;
//dp[fitst i weight][j capacity]
int at=1;
for(auto &[w,items] : by_weight){
sort(items.begin(),items.end(),greater<pair<int,int>>());
for(int cap=0;cap<=limit;cap++){
dp[at][cap]=dp[at-1][cap];
int copies=0;
int type_at=0;
int profit=0;
while((copies+1)*w<=cap && type_at<(int)items.size()){
copies++;
profit+=items[type_at].first;
if(dp[at-1][cap-copies*w]!=INT_MIN){
dp[at][cap]=max(dp[at][cap],dp[at-1][cap-copies*w]+profit);
}
if(copies==items[type_at].second){
type_at++;
copies=0;
}
}
}
at++;
}
cout << *max_element(dp.back().begin(),dp.back().end()) << '\n';
}
# | 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... |