# | TimeUTC-0 | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
743665 | ethening | Let's Win the Election (JOI22_ho_t3) | C++17 | 521 ms | 4784 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "bits/stdc++.h"
#include <functional>
#include <iomanip>
#include <vector>
using namespace std;
using ll = long long;
using pii = pair<int, int>;
int main() {
cin.tie(0)->sync_with_stdio(0);
int n, k;
cin >> n >> k;
vector<pii> pl(n + 5);
for (int i = 1; i <= n; i++) {
cin >> pl[i].first >> pl[i].second;
if (pl[i].second == -1) pl[i].second = 1e9;
}
sort(pl.begin() + 1, pl.begin() + n + 1, [](pii& u, pii& v) {
if (u.second == v.second) return u.first < v.first;
else return u.second < v.second;
});
// suffix[i][j] = min time cost to get j region in [i, n]
vector<vector<ll>> suffix(n + 5, vector<ll>(k + 5, 1e9));
for (int i = n; i >= 1; i--) {
for (int j = 0; j <= k; j++) {
if (j > n - i + 1) break; // j > no. of region in [i, n]
if (i == n) {
if (j == 0) suffix[i][j] = 0;
else if (j == 1) suffix[i][j] = pl[i].first;
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |