QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#620629 | #2559. Endless Road | hcywoi | RE | 35ms | 20380kb | C++23 | 6.4kb | 2024-10-07 19:54:51 | 2024-10-07 19:54:55 |
Judging History
answer
#include <bits/stdc++.h>
using i64 = long long;
template <typename T>
struct Fenwick {
int n;
std::vector<T> a;
Fenwick(int n = 0) {
init(n);
}
void init(int n) {
this->n = n;
a.assign(n, T());
}
void add(int x, T v) {
for (int i = x + 1; i <= n; i += i & -i) {
a[i - 1] += v;
}
}
T sum(int x) {
auto ans = T();
for (int i = x; i > 0; i -= i & -i) {
ans += a[i - 1];
}
return ans;
}
T rangesum(int l, int r) {
return sum(r) - sum(l);
}
int kth(T k) {
int x = 0;
for (int i = 1 << std::__lg(n); i; i /= 2) {
if (x + i <= n && k >= a[x + i - 1]) {
x += i;
k -= a[x - 1];
}
}
return x;
}
};
constexpr int N = 250010;
int cnt;
int id[N * 4], deg[N * 20];
std::vector<int> adj[N * 20];
void addEdge(int u, int v) {
// std::cerr << u << " " << v << "\n";
deg[v] ++ ;
adj[u].push_back(v);
}
void build(int p, int l, int r) {
id[p] = cnt ++ ;
if (l == r) {
return;
}
int m = (l + r) / 2;
build(p * 2, l, m);
build(p * 2 + 1, m + 1, r);
addEdge(id[p * 2], id[p]);
addEdge(id[p * 2 + 1], id[p]);
}
void add(int p, int l, int r, int x, int y, int z) {
if (l > y || r < x) {
return;
}
if (l >= x && r <= y) {
addEdge(id[p], z);
return;
}
int m = (l + r) / 2;
add(p * 2, l, m, x, y, z);
add(p * 2 + 1, m + 1, r, x, y, z);
}
void modify(int p, int l, int r, int x, int y) {
if (l == r) {
int New = cnt ++ ;
addEdge(id[p], New);
addEdge(y, New);
id[p] = New;
return;
}
int m = (l + r) / 2;
if (x <= m) {
modify(p * 2, l, m, x, y);
int New = cnt ++ ;
addEdge(id[p], New);
addEdge(id[p * 2], New);
id[p] = New;
} else {
modify(p * 2 + 1, m + 1, r, x, y);
int New = cnt ++ ;
addEdge(id[p], New);
addEdge(id[p * 2 + 1], New);
id[p] = New;
}
}
int main() {
// freopen("ds.in", "r", stdin);
// freopen("ds.out", "w", stdout);
std::ios::sync_with_stdio(false);
std::cin.tie(nullptr);
int n;
std::cin >> n;
std::vector<int> b(n * 2);
std::vector<std::array<int, 3>> a(n);
for (int i = 0; i < n; i ++ ) {
std::cin >> a[i][0] >> a[i][1];
a[i][2] = i;
b[i * 2] = a[i][0];
b[i * 2 + 1] = a[i][1];
}
std::sort(b.begin(), b.end());
b.erase(std::unique(b.begin(), b.end()), b.end());
int m = b.size();
for (int i = 0; i < n; i ++ ) {
a[i][0] = lower_bound(b.begin(), b.end(), a[i][0]) - b.begin();
a[i][1] = lower_bound(b.begin(), b.end(), a[i][1]) - b.begin();
}
std::sort(a.begin(), a.end(),
[&](std::array<int, 3> i, std::array<int, 3> j) {
return i[0] != j[0] ? i[0] > j[0] : i[2] < j[2];
});
std::set<int> s;
Fenwick<int> fen(m - 1);
for (int i = 0; i < m - 1; i ++ ) {
s.insert(i);
fen.add(i, b[i + 1] - b[i]);
}
auto update = [&](int l, int r) {
auto itl = s.lower_bound(l);
auto itr = s.upper_bound(r);
for (auto it = itl; it != itr; it ++ ) {
fen.add(*it, b[*it] - b[*it + 1]);
}
s.erase(itl, itr);
};
auto query = [&](int i) {
return fen.sum(a[i][1]) - fen.sum(a[i][0]);
};
// for (int i = 0; i < n; i ++ ) {
// std::cerr << a[i][0] << " " << a[i][1] << "\n";
// std::cerr << query(i) << "\n";
// }
cnt = n;
build(1, 0, m - 1);
for (int i = 0; i < n; i ++ ) {
add(1, 0, m - 1, 0, a[i][1], i);
modify(1, 0, m - 1, a[i][1], i);
}
std::queue<int> q;
for (int i = 0; i < cnt; i ++ ) {
if (!deg[i]) {
q.push(i);
}
}
std::vector<bool> vis(n);
std::priority_queue<std::array<int, 3>, std::vector<std::array<int, 3>>, std::greater<>> h;
std::set<std::pair<int, int>> seg;
for (int i = 0; i < n; i ++ ) {
while (!q.empty()) {
int x = q.front();
q.pop();
if (x < n) {
// std::cerr << x << "\n";
h.push({query(x), a[x][2], x});
seg.emplace(a[x][0], x);
} else {
for (auto y : adj[x]) {
if ( -- deg[y] == 0) {
q.push(y);
}
}
}
}
assert(!h.empty());
while (vis[h.top()[1]]) {
h.pop();
}
assert(!h.empty());
auto [_, x, y] = h.top();
h.pop();
std::cout << x + 1 << " \n"[i == n - 1];
vis[x] = true;
update(a[y][0], a[y][1] - 1);
seg.erase({a[y][0], y});
// for (int i = 0; i < n; i ++ ) {
// std::cerr << query(i) << " \n"[i == n - 1];
// }
if (!seg.empty()) {
int t = 1E9;
auto it = seg.lower_bound({a[y][0], 0});
while (true) {
if (it == seg.end() || it->first >= a[y][1]) {
break;
}
int x = it->second;
int w = query(x);
if (t < w) {
break;
}
// std::cerr << i << " " << x << "\n";
h.push({w, a[x][2], x});
t = w;
it ++ ;
}
t = 1E9;
it = seg.lower_bound({a[y][0], 0});
while (true) {
if (it == seg.begin() || a[(--it)->second][1] <= a[y][0]) {
break;
}
int x = it->second;
int w = query(x);
if (t < w) {
break;
}
// std::cerr << i << " " << x << "\n";
h.push({w, a[x][2], x});
t = w;
}
}
for (auto z : adj[y]) {
if ( -- deg[z] == 0) {
q.push(z);
}
}
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 6ms
memory: 7652kb
input:
6 1 2 2 3 3 4 4 5 1 3 3 5
output:
1 2 5 3 4 6
result:
ok 6 tokens
Test #2:
score: 0
Accepted
time: 6ms
memory: 7656kb
input:
4 3 7 10 14 1 6 6 11
output:
1 3 2 4
result:
ok 4 tokens
Test #3:
score: 0
Accepted
time: 6ms
memory: 7668kb
input:
100 50 51 49 51 49 52 48 52 48 53 47 53 47 54 46 54 46 55 45 55 45 56 44 56 44 57 43 57 43 58 42 58 42 59 41 59 41 60 40 60 40 61 39 61 39 62 38 62 38 63 37 63 37 64 36 64 36 65 35 65 35 66 34 66 34 67 33 67 33 68 32 68 32 69 31 69 31 70 30 70 30 71 29 71 29 72 28 72 28 73 27 73 27 74 26 74 26 75 25...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
result:
ok 100 tokens
Test #4:
score: 0
Accepted
time: 6ms
memory: 7716kb
input:
100 41 42 99 100 47 48 50 51 56 57 61 62 27 28 85 86 44 45 3 4 26 27 20 21 92 93 33 34 86 87 69 70 84 85 62 63 81 82 2 3 13 14 32 33 82 83 70 71 46 47 45 46 19 20 83 84 57 59 63 65 59 61 82 84 45 47 48 50 70 72 42 44 84 86 26 28 61 63 2 4 17 19 65 67 54 56 67 69 96 99 42 45 47 50 34 37 14 17 51 54 7...
output:
1 2 3 4 5 6 7 8 9 10 11 38 12 13 14 15 16 17 37 18 39 19 20 40 21 22 23 24 25 26 33 27 28 32 35 29 30 31 57 73 34 47 71 36 46 41 53 42 58 43 54 44 52 77 45 63 48 62 49 64 80 50 60 79 91 51 66 89 55 65 83 56 59 67 86 61 72 82 90 96 68 75 81 93 69 74 84 92 70 87 88 94 97 99 76 78 85 95 98 100
result:
ok 100 tokens
Test #5:
score: 0
Accepted
time: 6ms
memory: 7988kb
input:
100 26 27 68 69 33 34 96 97 42 43 6 7 60 61 22 23 9 10 19 20 38 39 7 8 73 74 64 65 53 54 84 85 15 16 79 80 62 63 11 12 32 33 80 81 95 96 54 55 83 84 89 90 55 56 74 75 97 98 81 82 23 24 57 58 14 15 34 35 59 60 40 41 46 47 18 19 21 22 56 57 35 36 69 70 82 83 94 95 63 64 86 87 31 32 76 77 39 40 47 48 4...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
result:
ok 100 tokens
Test #6:
score: 0
Accepted
time: 6ms
memory: 7820kb
input:
100 66 67 42 43 32 33 28 29 96 97 19 20 41 42 38 39 73 74 50 51 31 32 40 41 3 4 72 73 29 30 45 46 14 15 11 12 68 69 21 22 25 26 51 52 75 76 76 77 8 9 99 100 53 54 27 28 61 62 26 27 74 75 84 85 64 65 79 80 71 72 85 86 33 34 0 1 90 91 24 25 4 6 51 53 64 66 34 36 94 96 66 68 97 99 31 33 80 82 19 21 88 ...
output:
1 2 3 4 5 6 7 8 9 10 11 48 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 76 81 31 66 32 33 34 35 36 59 37 38 39 40 42 43 46 50 55 57 64 41 44 62 74 78 87 90 45 71 47 49 51 69 52 53 54 82 56 58 72 60 68 73 61 63 91 65 75 67 70 84 94 95 77 79 88 96 98 80 89 83 85 86 92 93 97 99 100
result:
ok 100 tokens
Test #7:
score: 0
Accepted
time: 3ms
memory: 8012kb
input:
100 69 70 15 16 55 56 91 92 34 35 92 93 20 21 10 11 22 23 4 5 82 83 86 87 77 78 49 50 65 66 29 30 83 84 1 2 13 14 30 31 32 33 0 1 19 20 48 49 31 33 87 89 8 10 92 94 54 56 21 23 57 59 51 53 1 3 83 85 77 79 63 65 31 34 46 49 7 10 80 83 24 27 91 94 74 77 66 69 51 54 77 80 20 23 56 59 34 37 43 46 87 90 ...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 28 42 29 30 47 33 34 35 37 46 55 26 51 59 61 68 27 39 56 63 69 71 31 48 32 45 36 38 40 65 78 49 54 62 74 77 73 76 41 64 79 43 44 58 66 50 52 67 60 72 53 57 70 75 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
result:
ok 100 tokens
Test #8:
score: 0
Accepted
time: 3ms
memory: 8012kb
input:
100 27 28 56 57 79 80 34 35 98 99 31 32 55 56 67 68 25 26 47 48 58 59 46 47 49 50 42 43 80 81 43 44 83 84 90 91 48 49 82 83 59 60 81 82 92 93 91 92 69 70 30 31 77 78 66 67 50 51 54 55 63 64 57 58 26 27 28 29 11 12 68 70 26 28 35 37 44 46 74 76 87 89 93 95 10 12 83 85 32 34 97 99 37 39 28 30 64 66 76...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 37 34 35 36 43 44 46 48 65 50 53 58 60 62 64 66 67 68 70 71 73 77 80 84 85 87 88 89 91 38 54 39 40 61 79 41 74 78 82 42 76 83 93 45 63 75 47 49 59 69 51 55 72 81 90 86 95 92 94 96 97 98 99 52 56 57 100
result:
ok 100 tokens
Test #9:
score: 0
Accepted
time: 23ms
memory: 20380kb
input:
10000 504758807 504763364 504735683 504763364 504735683 504807338 504507299 504807338 504507299 504809080 504428573 504809080 504428573 504842988 504407969 504842988 504407969 504925719 504242659 504925719 504242659 504982796 504192499 504982796 504192499 504988790 504164090 504988790 504164090 5049...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 ...
result:
ok 10000 tokens
Test #10:
score: 0
Accepted
time: 32ms
memory: 19048kb
input:
10000 970160455 970160479 932488256 932488310 383539934 383539995 375340196 375340274 865733105 865733219 735585223 735585367 687954828 687955008 870182994 870183203 320739206 320739425 905982784 905983157 628124616 628125095 558426226 558426706 562201395 562201974 439234363 439234971 709751667 7097...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 ...
result:
ok 10000 tokens
Test #11:
score: 0
Accepted
time: 35ms
memory: 18584kb
input:
10000 410601820 410601821 294090792 294090799 441422212 441422222 670420210 670420222 59461862 59461893 90469319 90469353 179055474 179055527 252981238 252981294 283998869 283998965 490236705 490236809 841458496 841458612 851847119 851847283 849148457 849148637 294090609 294090792 483689813 48369000...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 ...
result:
ok 10000 tokens
Test #12:
score: 0
Accepted
time: 29ms
memory: 20160kb
input:
10000 495013411 495013425 999006846 999006868 296771081 296771115 150818948 150819019 642881267 642881350 560800096 560800192 138097500 138097596 21121422 21121529 109953510 109953653 428516381 428516550 958914894 958915117 714510610 714510838 412832098 412832339 343551761 343552012 778598526 778598...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 ...
result:
ok 10000 tokens
Test #13:
score: 0
Accepted
time: 35ms
memory: 19800kb
input:
10000 350318312 350318340 149202565 149202603 179261197 179261247 779925340 779925446 194445305 194445467 848400332 848400535 522118665 522118875 822005975 822006190 825371374 825371610 136200561 136200830 788364490 788364769 859844322 859844733 643922682 643923146 901332582 901333056 388316426 3883...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 49 43 44 45 46 47 48 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 ...
result:
ok 10000 tokens
Test #14:
score: 0
Accepted
time: 22ms
memory: 17904kb
input:
10000 512474957 512474969 736102015 736102067 678460955 678461007 586742723 586742795 865924891 865924995 896796735 896796877 328184375 328184586 487430461 487430675 657033983 657034205 797801001 797801273 677420006 677420297 285432467 285432761 408167954 408168287 334723223 334723567 832094664 8320...
output:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 ...
result:
ok 10000 tokens
Test #15:
score: -100
Runtime Error
input:
250000 500096771 500097498 500096275 500097498 500096275 500100939 500093322 500100939 500093322 500112779 500090810 500112779 500090810 500115618 500088604 500115618 500088604 500126767 500084824 500126767 500084824 500133232 500083865 500133232 500083865 500139175 500077522 500139175 500077522 500...