Submission #1014622

#TimeUsernameProblemLanguageResultExecution timeMemory
1014622UnforgettableplCarnival Tickets (IOI20_tickets)C++17
27 / 100
386 ms91136 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; void allocate_tickets( std::vector<std::vector<int>> _x); pair<ll,vector<vector<int>>> findans1(int k,vector<vector<int>> x){ int n = x.size(); int m = x[0].size(); vector<deque<pair<ll,ll>>> q; for(auto&i:x){ q.emplace_back(); int idx = 0; for(int&j:i)q.back().emplace_back(j,idx++); } vector<vector<int>> anss(n,vector<int>(m,-1)); ll ans=0; for(int round=0;round<k;round++){ vector<bool> status(n); //True means max taken priority_queue<pair<ll,ll>> deltaq; for(int i=0;i<n;i++){ ans-=q[i].front().first; deltaq.emplace(q[i].back().first+q[i].front().first,i); } for(int i=0;i<n/2;i++){ auto [change,idx] = deltaq.top();deltaq.pop(); ans+=change; status[idx]=true; } for(int i=0;i<n;i++){ if(status[i]){ anss[i][q[i].back().second]=round; q[i].pop_back(); } else { anss[i][q[i].front().second]=round; q[i].pop_front(); } } } return {ans,anss}; } pair<ll,vector<vector<int>>> findans2(int k,vector<vector<int>> x){ int n = x.size(); int m = x[0].size(); vector<deque<pair<ll,ll>>> q; for(auto&i:x){ q.emplace_back(); int idx = 0; for(int&j:i)q.back().emplace_back(j,idx++); } vector<vector<int>> anss(n,vector<int>(m,-1)); ll ans=0; for(int round=0;round<k;round++){ vector<bool> status(n,true); //True means max taken priority_queue<pair<ll,ll>> deltaq; for(int i=0;i<n;i++){ ans-=q[i].back().first; deltaq.emplace(-q[i].back().first-q[i].front().first,i); } for(int i=0;i<n/2;i++){ auto [change,idx] = deltaq.top();deltaq.pop(); ans+=change; status[idx]=false; } for(int i=0;i<n;i++){ if(status[i]){ anss[i][q[i].back().second]=round; q[i].pop_back(); } else { anss[i][q[i].front().second]=round; q[i].pop_front(); } } } return {ans,anss}; } long long find_maximum(int k, std::vector<std::vector<int>> x) { auto base = findans1(k,x); auto base2 = findans2(k,x); if(base.first>base2.first){ allocate_tickets(base.second); return base.first; } else { allocate_tickets(base2.second); return base2.first; } }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...