Submission #406051

#TimeUsernameProblemLanguageResultExecution timeMemory
406051tiberiuCarnival Tickets (IOI20_tickets)C++14
0 / 100
1 ms204 KiB
#include "tickets.h" #include <vector> #include <algorithm> #include <iostream> #include <queue> #include <set> using namespace std; typedef pair<int, int> pii; long long find_maximum(int k, vector<vector<int>> x) { int n = x.size(); int m = x[0].size(); vector<vector<int>> ans = vector<vector<int>>(n, vector<int>(m, -1)); set<pii> unused[n], mins[n], maxs[n]; for (int i = 0; i < n; i++) for (int j = 0; j < m; j++) unused[i].insert({x[i][j], j}); priority_queue<pii> best; long long win = 0; for (int i = 0; i < n; i++) { for (int j = 0; j < k; j++) { // cerr << "Unused: " << unused[i].begin()->first << endl; win -= unused[i].begin()->first; mins[i].insert(*unused[i].begin()); unused[i].erase(unused[i].begin()); } best.push({mins[i].rbegin()->first + (unused[i].size() ? unused[i].rbegin()->first : mins[i].rbegin()->first), i}); // cerr << "Inserted: " << mins[i].rbegin()->first << endl; } for (int ix = 0; ix < k * n / 2; ix++) { pii b = best.top(); best.pop(); win += b.first; int c = b.second; // cerr << b.first << endl; if (unused[c].size()) { maxs[c].insert(*unused[c].rbegin()); unused[c].erase(*unused[c].rbegin()); unused[c].insert(*mins[c].rbegin()); } else { maxs[c].insert(*mins[c].rbegin()); } mins[c].erase(*mins[c].rbegin()); if (mins[c].size()) { best.push({mins[c].rbegin()->first + (unused[c].size() ? unused[c].rbegin()->first : mins[c].rbegin()->first), c}); } } for (int r = 0; r < k; r++) { vector<pii> c; for (int j = 0; j < n; j++) { c.push_back({maxs[j].size(), j}); // cout << c.back().first << ' '; } // cout << endl; sort(c.begin(), c.end()); for (int i = 0; i < n / 2; i++) { int col = c[i].second; int ix = mins[col].begin()->second; win -= x[col][ix]; ans[col][ix] = r; mins[col].erase({x[col][ix], ix}); } for (int i = n / 2; i < n; i++) { int col = c[i].second; int ix = maxs[col].begin()->second; win += x[col][ix]; ans[col][ix] = r; maxs[col].erase({x[col][ix], ix}); } } allocate_tickets(ans); return win; }
#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...