QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#565431 | #9310. Permutation Counting 4 | electricstick | TL | 2954ms | 97728kb | C++20 | 2.0kb | 2024-09-15 21:16:17 | 2024-09-15 21:16:18 |
Judging History
answer
#include<cstdio>
#include<set>
#include<algorithm>
const int N = 1e6 + 10;
int n;
std::multiset<int> l[N], r[N], tmp;
std::multiset<std::pair<int, int>> lp, rp;
template<class T>
void erase(std::multiset<T>& st, const T& val) {
if(auto v = st.find(val); v != st.end()) {
st.erase(v);
}
}
void del(int li, int ri){
erase(lp, {l[li].size(), li});
erase(rp, {r[ri].size(), ri});
erase(l[li], ri);
erase(r[ri], li);
lp.insert({l[li].size(), li});
rp.insert({r[ri].size(), ri});
}
void add(int li, int ri){
erase(lp, {l[li].size(), li});
erase(rp, {r[ri].size(), ri});
l[li].insert(ri);
r[ri].insert(li);
lp.insert({l[li].size(), li});
rp.insert({r[ri].size(), ri});
}
int work() {
while(true) {
if(lp.rbegin()->first >= rp.rbegin()->first) {
auto mx = *lp.rbegin();
if(mx.first == 1) {
return 1;
}
auto mxl = mx.second;
lp.erase(mx);
int las = mxl;
tmp.clear();
tmp.swap(l[mxl]);
for(auto rit = tmp.begin(); rit != tmp.end(); ++rit) {
auto ri = *rit;
if(ri < las) {
return 0;
}
del(mxl, ri);
add(las, ri);
las = ri + 1;
}
} else {
auto mx = *rp.rbegin();
if(mx.first == 1) {
return 1;
}
auto mxr = mx.second;
rp.erase(mx);
int las = mxr;
tmp.clear();
tmp.swap(r[mxr]);
for(auto lit = tmp.rbegin(); lit != tmp.rend(); ++lit) {
auto li = *lit;
if(li > las) {
return 0;
}
del(li, mxr);
add(li, las);
las = li - 1;
}
}
}
}
int main() {
int t; scanf("%d", &t);
while(t--) {
scanf("%d", &n);
lp.clear();
rp.clear();
for(int i = 1; i <= n; i++) {
l[i].clear();
r[i].clear();
}
for(int i = 1, li, ri; i <= n; i++) {
scanf("%d%d", &li, &ri);
add(li, ri);
}
printf("%d\n", work());
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 14ms
memory: 97580kb
input:
4 5 1 2 1 5 1 2 1 2 2 2 5 1 1 2 4 2 3 5 5 3 4 5 3 5 1 2 3 4 3 5 3 3 5 1 5 1 4 4 5 5 5 1 2
output:
0 1 0 0
result:
ok 4 tokens
Test #2:
score: 0
Accepted
time: 1227ms
memory: 97728kb
input:
66725 14 7 7 4 6 7 8 8 13 2 13 6 13 6 10 14 14 1 10 9 11 7 9 3 8 4 12 5 12 12 2 6 3 6 7 11 2 5 1 1 6 12 8 12 2 3 7 9 7 8 1 10 1 4 10 4 8 4 4 6 10 9 10 2 3 2 7 1 3 3 4 2 2 3 10 20 3 12 10 14 19 20 19 20 1 9 7 9 13 16 17 17 16 18 2 11 5 19 6 17 11 17 3 6 3 11 7 20 8 17 3 18 10 15 9 20 16 5 10 2 10 2 1...
output:
1 1 0 0 1 0 1 1 0 1 1 0 0 0 0 0 1 0 1 0 0 1 0 0 0 1 0 1 0 0 0 0 1 0 1 1 1 1 1 0 1 0 1 1 1 1 1 1 1 1 0 1 1 0 0 0 0 0 0 1 0 1 1 0 1 1 1 0 1 0 1 0 0 0 1 1 1 0 0 1 1 1 1 0 1 1 1 1 1 1 1 0 1 0 0 1 1 0 0 1 1 0 0 1 1 1 1 1 1 0 0 1 1 1 0 0 1 1 0 0 1 0 1 0 1 0 1 0 0 0 0 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 1 0 1 1 ...
result:
ok 66725 tokens
Test #3:
score: 0
Accepted
time: 2954ms
memory: 97688kb
input:
6655 155 28 58 68 100 6 47 98 109 11 133 38 153 73 118 126 153 24 43 71 118 109 135 6 104 40 101 24 139 100 136 135 136 40 148 70 117 92 124 63 64 45 55 16 128 65 86 20 49 126 138 30 141 127 146 21 155 49 139 27 34 39 145 20 53 12 41 3 107 38 78 106 109 61 102 20 99 134 135 23 99 10 69 105 113 36 75...
output:
0 0 1 1 0 1 0 0 1 1 0 1 1 1 0 0 1 1 1 0 1 0 1 0 1 0 0 1 1 0 1 0 0 0 1 1 0 1 0 1 0 1 0 1 1 1 1 0 1 0 0 0 0 0 1 1 0 1 0 1 0 1 0 1 0 0 1 0 0 1 0 0 0 1 0 1 1 0 1 0 0 0 0 0 0 1 0 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 1 0 1 1 0 0 0 0 0 1 0 1 0 1 0 0 0 0 1 0 1 0 0 1 0 1 0 0 1 0 1 0 0 1 1 1 0 0 0 0 ...
result:
ok 6655 tokens
Test #4:
score: -100
Time Limit Exceeded
input:
666 1967 396 1664 818 1954 564 805 1106 1322 568 1687 853 1482 153 1092 566 670 154 562 114 1372 574 1879 482 1083 499 1566 2 1384 291 1947 122 1714 1277 1900 740 1024 887 1478 146 254 944 1807 574 1193 225 1933 43 1278 1017 1482 958 1180 86 1230 1658 1679 980 1542 1044 1127 762 989 1128 1567 552 17...