Submission #906431

#TimeUsernameProblemLanguageResultExecution timeMemory
906431SalihSahinAkcija (COCI21_akcija)C++17
10 / 110
5061 ms91184 KiB
#include<bits/stdc++.h> #define int long long #define pb push_back #define mp make_pair using namespace std; const int mod = 1e9 + 7; const int inf = 1e17*2; const int N = 2e5 + 5; int32_t main(){ cin.tie(0); cout.tie(0); ios_base::sync_with_stdio(false); int n, k; cin>>n>>k; multiset<int> best[n+2]; best[0].insert(0); vector<pair<int, int> > a(n); for(int i = 0; i < n; i++){ cin>>a[i].second>>a[i].first; } sort(a.begin(), a.end()); for(int i = 0; i < n; i++){ for(int j = a[i].first-1; j >= 0; j--){ for(auto itr: best[j]){ int val = a[i].second + itr; if(best[j+1].size() >= j+1){ auto kp = best[j+1].rbegin(); if(val < *kp){ best[j+1].insert(val); if(best[j+1].size() > j+1){ auto p = best[j+1].end(); p--; best[j+1].erase(p); } } else break; } else{ best[j+1].insert(val); } } } } vector<pair<int, int> > ans; for(int i = n; i >= 0; i--){ for(auto itr: best[i]){ ans.pb(mp(i, itr)); } if(ans.size() > k) break; } for(int i = 0; i < k; i++){ cout<<ans[i].first<<" "<<ans[i].second<<endl; } return 0; }

Compilation message (stderr)

Main.cpp: In function 'int32_t main()':
Main.cpp:28:37: warning: comparison of integer expressions of different signedness: 'std::multiset<long long int>::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
   28 |                 if(best[j+1].size() >= j+1){
      |                    ~~~~~~~~~~~~~~~~~^~~~~~
Main.cpp:32:45: warning: comparison of integer expressions of different signedness: 'std::multiset<long long int>::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
   32 |                         if(best[j+1].size() > j+1){
      |                            ~~~~~~~~~~~~~~~~~^~~~~
Main.cpp:53:23: warning: comparison of integer expressions of different signedness: 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
   53 |         if(ans.size() > k) 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...
#Verdict Execution timeMemoryGrader output
Fetching results...