제출 #966369

#제출 시각아이디문제언어결과실행 시간메모리
966369njoopKnapsack (NOI18_knapsack)C++14
100 / 100
323 ms5844 KiB
#include <bits/stdc++.h> #define ll long long #define ti tuple<int, int, int> using namespace std; int s, n, k, v, w, cw, cv; ll dp[2010], ans; ti arr[1000010]; priority_queue<int, vector<int>, greater<int>> pq[2010]; vector<pair<int, int>> item; int main() { cin.tie(0)->sync_with_stdio(0); cin >> s >> n; for(int i=0; i<n; i++) { cin >> v >> w >> k; arr[i] = {v, w, k}; } sort(arr, arr+n, greater<ti>()); for(int i=0; i<n; i++) { v = get<0>(arr[i]); w = get<1>(arr[i]); k = get<2>(arr[i]); k = min(k, s/w); while(k--) { pq[w].push(v); if(pq[w].size() > s/w) break; } } for(int i=1; i<=s; i++) { while(!pq[i].empty()) { item.push_back({i, pq[i].top()}); pq[i].pop(); } } for(auto i: item) { cw = i.first; cv = i.second; for(int j=s; j>=0; j--) { if(dp[j] == 0 && j != 0) continue; if(cw + j <= s) dp[cw+j] = max(dp[cw+j], dp[j]+cv); } } for(int i=0; i<=s; i++) { ans = max(ans, dp[i]); } cout << ans; return 0; }

컴파일 시 표준 에러 (stderr) 메시지

knapsack.cpp: In function 'int main()':
knapsack.cpp:27:29: warning: comparison of integer expressions of different signedness: 'std::priority_queue<int, std::vector<int>, std::greater<int> >::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   27 |             if(pq[w].size() > s/w) break;
      |                ~~~~~~~~~~~~~^~~~~
#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...