제출 #1014570

#제출 시각아이디문제언어결과실행 시간메모리
1014570Unforgettablepl카니발 티켓 (IOI20_tickets)C++17
27 / 100
356 ms110288 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; void allocate_tickets( std::vector<std::vector<int>> _x); long long find_maximum(int k, std::vector<std::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(); } } } allocate_tickets(anss); return ans; }
#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...