Submission #1016849

#TimeUsernameProblemLanguageResultExecution timeMemory
1016849sexo69696969Knapsack (NOI18_knapsack)C++14
49 / 100
109 ms262144 KiB
#include <bits/stdc++.h> using namespace std; #ifdef local #include "debug.hpp" #define pr(...) debug(#__VA_ARGS__, __VA_ARGS__) #define prs(...) debug_nameless(__VA_ARGS__) #else #define pr(...) 69 #define prs(...) 69 #endif #define endl '\n' #define int long long const int inf = 1e9; const long long binf = 1e18; struct Item{ int p, w, f; }; void solve(int tc){ int s, n; cin >> s >> n; vector <vector<Item>> items(s+1); for(int i = 0; i < n; i++){ int p, w, f; cin >> p >> w >> f; items[w].push_back({p, w, f}); } for(auto it : items){ sort(it.begin(), it.end(), [&](Item a, Item b){return a.p > b.p;}); } vector <pair<int,int>> arr; for(int i = 1; i <= s; i++){ for(int pos = 0; pos < items[i].size(); pos++){ int total = 0; for(int j = 0; j < items[i][pos].f && total < s; j++){ arr.push_back({items[i][pos].w, items[i][pos].p}); total += items[i][pos].w; } } } //do knapsack vector <vector<int>> dp(arr.size()+1, vector<int>(s+1, 0)); for(int i = 1; i <= arr.size(); i++){ for(int j = 0; j <= s; j++){ dp[i][j] = dp[i-1][j]; if(j - arr[i-1].first >= 0){ dp[i][j] = max(dp[i][j], dp[i-1][j-arr[i-1].first] + arr[i-1].second); } } } cout << dp[arr.size()][s] << endl; } signed main(){ ios_base::sync_with_stdio(0); cin.tie(0); int tc = -1; tc = 1; if(tc != 1) cin >> tc; for(int t = 0; t < tc; t++){ pr(t); prs(string(50, '-')); solve(t); prs(string(50, '-') + "\n"); } return 0; }

Compilation message (stderr)

knapsack.cpp: In function 'void solve(long long int)':
knapsack.cpp:38:26: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<Item>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   38 |     for(int pos = 0; pos < items[i].size(); pos++){
      |                      ~~~~^~~~~~~~~~~~~~~~~
knapsack.cpp:48:20: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   48 |   for(int i = 1; i <= arr.size(); i++){
      |                  ~~^~~~~~~~~~~~~
knapsack.cpp: In function 'int main()':
knapsack.cpp:9:19: warning: statement has no effect [-Wunused-value]
    9 |   #define pr(...) 69
      |                   ^~
knapsack.cpp:67:5: note: in expansion of macro 'pr'
   67 |     pr(t); prs(string(50, '-'));
      |     ^~
knapsack.cpp:10:20: warning: statement has no effect [-Wunused-value]
   10 |   #define prs(...) 69
      |                    ^~
knapsack.cpp:67:12: note: in expansion of macro 'prs'
   67 |     pr(t); prs(string(50, '-'));
      |            ^~~
knapsack.cpp:10:20: warning: statement has no effect [-Wunused-value]
   10 |   #define prs(...) 69
      |                    ^~
knapsack.cpp:69:5: note: in expansion of macro 'prs'
   69 |     prs(string(50, '-') + "\n");
      |     ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...