Submission #300872

#TimeUsernameProblemLanguageResultExecution timeMemory
300872SortingCarnival Tickets (IOI20_tickets)C++17
27 / 100
824 ms51468 KiB
#include "tickets.h" #include <bits/stdc++.h> using namespace std; long long find_maximum(int k, vector<vector<int>> x) { int n = x.size(); int m = x[0].size(); vector<vector<int>> c(n, vector<int>(m, -1)); int iter = n / 2 * k; priority_queue<array<int, 2>, vector<array<int, 2>>, greater<array<int, 2>>> pq; long long ans = 0; vector<int> pos(n, 0); for(int i = 0; i < n; ++i) for(int j = m - k; j < m; ++j) ans += x[i][j]; for(int i = 0; i < n; ++i) pq.push({x[i][0] + x[i][m - k], i}); for(int i = 0; i < iter; ++i){ auto [sub, idx] = pq.top(); pq.pop(); ans -= sub; pos[idx]++; if(pos[idx] + m - k < m) pq.push({x[idx][pos[idx]] + x[idx][pos[idx] + m - k], idx}); } vector<int> cnt(m, 0); for(int i = 0; i < n; ++i){ int j2 = 0, j3 = pos[i] + m - k; for(int j = 0; j < k; ++j){ if(cnt[j] == n / 2 || j2 == pos[i]){ c[i][j3] = j; j3++; } else{ c[i][j2] = j; cnt[j]++; j2++; } } } allocate_tickets(c); 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...