제출 #543538

#제출 시각아이디문제언어결과실행 시간메모리
543538sliviu카니발 티켓 (IOI20_tickets)C++17
27 / 100
526 ms51340 KiB
#include <bits/stdc++.h> #include <tickets.h> using namespace std; using ll = long long; ll find_maximum(int k, vector<vector<int>> x) { int n = x.size(), m = x[0].size(); ll ans = 0; vector<int> pos(n, k - 1); vector<vector<int>> sol(n, vector<int>(m, -1)); priority_queue<pair<int, int>> PQ; for (int i = 0; i < n; ++i) { for (int j = 0; j < k; ++j) ans -= x[i][j]; PQ.emplace(x[i][k - 1] + x[i][m - 1], i); } for (int i = 0; i < n * k / 2; ++i) { auto [s, j] = PQ.top(); PQ.pop(); ans += s; if (--pos[j] >= 0) PQ.emplace(x[j][pos[j]] + x[j][m - k + pos[j]], i); } for (int i = 0, l = 0, r = k - 1; i < n; ++i) { for (int j = 0; j <= pos[i]; ++j) sol[i][j] = l, l = (l + 1) % k; for (int j = m - 1; j > m - k + pos[i]; --j) sol[i][j] = r, r = (r - 1 + k) % k; } allocate_tickets(sol); 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...