QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#283600 | #6633. Exam Requirements | jrjyy | AC ✓ | 1229ms | 460784kb | C++20 | 4.7kb | 2023-12-14 21:32:09 | 2023-12-14 21:32:09 |
Judging History
answer
#include <bits/stdc++.h>
using i64 = long long;
struct TwoSat {
int n;
std::vector<std::vector<int>> e;
std::vector<bool> ans;
TwoSat(int n_) : n{n_}, e(2 * n), ans(n) {}
void emplace_back() {
n += 1;
e.resize(2 * n);
ans.resize(n);
}
void addClause(int u, bool f, int v, bool g) {
e[2 * u + !f].push_back(2 * v + g);
e[2 * v + !g].push_back(2 * u + f);
}
bool satisfiable() {
std::vector<int> dfn(2 * n, -1), low(2 * n), stk, id(2 * n, -1);
int cur = 0, cnt = 0;
auto dfs = [&](auto self, int u) -> void {
dfn[u] = low[u] = cur++;
stk.push_back(u);
for (auto v : e[u]) {
if (dfn[v] == -1) {
self(self, v);
low[u] = std::min(low[u], low[v]);
} else if (id[v] == -1) {
low[u] = std::min(low[u], dfn[v]);
}
}
if (dfn[u] == low[u]) {
for (int x = -1; x != u; stk.pop_back()) {
x = stk.back();
id[x] = cnt;
}
++cnt;
}
};
for (int u = 0; u < 2 * n; ++u) {
if (dfn[u] == -1) {
dfs(dfs, u);
}
}
for (int i = 0; i < n; ++i) {
if (id[2 * i] == id[2 * i + 1]) {
return false;
}
ans[i] = id[2 * i] > id[2 * i + 1];
}
return true;
}
std::vector<bool> answer() const {
return ans;
}
};
struct Node {
Node *l{}, *r{};
int v = -1;
};
int val(Node *u) {
return u ? u->v : -1;
}
template <typename F>
void modify(Node *&u, int l, int r, int p, int x, F &&f) {
if (!u) {
u = new Node{};
}
if (r - l == 1) {
u->v = f(val(u), x);
return;
}
int m = (l + r) / 2;
if (p < m) {
modify(u->l, l, m, p, x, f);
} else {
modify(u->r, m, r, p, x, f);
}
u->v = f(val(u->l), val(u->r));
}
template <typename F>
void rangeApply(Node *u, int l, int r, int ql, int qr, F &&f) {
if (!u || r <= ql || qr <= l) {
return;
}
if (ql <= l && r <= qr) {
f(u->v);
return;
}
int m = (l + r) / 2;
rangeApply(u->l, l, m, ql, qr, f);
rangeApply(u->r, m, r, ql, qr, f);
}
void solve() {
int n, m;
std::cin >> n >> m;
std::vector<int> s(n), t(n), v;
for (int i = 0; i < n; ++i) {
std::cin >> s[i] >> t[i];
++t[i];
v.push_back(s[i]);
v.push_back(t[i]);
}
std::sort(v.begin(), v.end());
v.erase(std::unique(v.begin(), v.end()), v.end());
for (int i = 0; i < n; ++i) {
s[i] = std::lower_bound(v.begin(), v.end(), s[i]) - v.begin();
t[i] = std::lower_bound(v.begin(), v.end(), t[i]) - v.begin();
}
const int k = int(v.size());
std::vector<std::pair<int, int>> a;
for (int i = 0; i < m; ++i) {
int u, v;
std::cin >> u >> v;
--u, --v;
a.emplace_back(u, v);
}
TwoSat ts(n);
auto work = [&]() {
std::vector<std::vector<int>> mdf(k), qry(k);
for (int i = 0; i < n; ++i) {
mdf[t[i]].push_back(i);
qry[s[i]].push_back(i);
}
Node *root{};
for (int x = k - 1; x >= 0; --x) {
for (auto i : qry[x]) {
auto f = [&](int u) {
ts.e[2 * i + 1].push_back(u);
};
rangeApply(root, 0, k, 0, s[i], f);
rangeApply(root, 0, k, s[i] + 1, t[i], f);
}
for (auto i : mdf[x]) {
modify(root, 0, k, s[i], 2 * i, [&](int u, int v) {
if (u == -1) {
return v;
}
if (v == -1) {
return u;
}
int x = ts.n;
ts.emplace_back();
ts.e[2 * x].push_back(u);
ts.e[2 * x].push_back(v);
return 2 * x;
});
}
}
};
work();
for (int i = 0; i < n; ++i) {
std::tie(s[i], t[i]) = std::make_pair(k - 1 - t[i], k - 1 - s[i]);
}
work();
for (auto [u, v] : a) {
ts.addClause(u, true, v, true);
}
if (ts.satisfiable()) {
std::cout << "YES\n";
} else {
std::cout << "NO\n";
}
}
int main() {
std::cin.tie(nullptr)->sync_with_stdio(false);
int t;
std::cin >> t;
while (t--) {
solve();
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3472kb
input:
2 3 1 1 5 2 7 10 11 2 1 3 3 1 5 2 7 5 7 1 2 2 3 3 1
output:
YES NO
result:
ok 2 lines
Test #2:
score: 0
Accepted
time: 430ms
memory: 237436kb
input:
1 100000 100000 15084647 15220430 217541056 217598054 222963701 223110976 71224450 71340221 320463268 320631387 334861459 334924668 328950591 329083669 178996498 178996584 428529461 428605033 405428435 405504132 197936687 197947412 9058562 9190197 169407597 169474101 297518153 297590927 31471874 316...
output:
NO
result:
ok single line: 'NO'
Test #3:
score: 0
Accepted
time: 438ms
memory: 237496kb
input:
1 100000 100000 14748507 14846251 125029948 125054609 463293218 463377641 198157217 198174486 61816219 61983451 43817835 43922214 146858750 146954988 30320405 30474901 19982332 20115324 118096811 118227915 446543803 446714206 334272499 334330640 334038396 334098710 142811467 142826092 343928730 3441...
output:
YES
result:
ok single line: 'YES'
Test #4:
score: 0
Accepted
time: 437ms
memory: 238300kb
input:
1 100000 100000 14378753 14427960 285902694 286019349 63076522 63199196 123034896 123091554 180956618 180971192 104893331 105077844 42717572 42770533 300075985 300247179 24213843 24240797 183255507 183392441 49921960 50077350 425570312 425743586 159753369 159916921 92930583 93006150 17541601 1766290...
output:
YES
result:
ok single line: 'YES'
Test #5:
score: 0
Accepted
time: 448ms
memory: 237496kb
input:
1 100000 100000 14008999 14009669 95199087 95219736 14436179 14597104 47912575 48008622 300097017 300106580 314204474 314321474 438388394 438398078 421595918 421783810 28445354 28554270 396649850 396832967 301347764 301488141 17056125 17196885 485280342 485399485 43049699 43186208 190966472 19098875...
output:
YES
result:
ok single line: 'YES'
Test #6:
score: 0
Accepted
time: 422ms
memory: 239144kb
input:
1 100000 100000 13605631 13735266 306114981 306163955 473109270 473261902 418782813 418868140 297212864 297253645 375822737 375911188 60621526 60621849 313499877 313647461 297219858 297394925 462722513 462902236 259120962 259259635 226014167 226123040 323655842 323840004 97994617 98082806 225359358 ...
output:
NO
result:
ok single line: 'NO'
Test #7:
score: 0
Accepted
time: 528ms
memory: 251308kb
input:
1 100000 100000 12378720 13625648 465814237 466616175 208691613 209863741 487589042 488474978 34489188 35271208 388644733 390469725 295170077 296291628 26123414 27676512 312050690 313755540 489093309 489538591 237262253 237973586 236118231 236780639 322598076 322794715 218797919 220330870 88459847 8...
output:
NO
result:
ok single line: 'NO'
Test #8:
score: 0
Accepted
time: 515ms
memory: 251604kb
input:
1 100000 100000 12025773 12899766 251831056 252958999 302794200 304237851 15424265 15656468 118197510 119570581 273660669 274814313 324357744 325209060 260709334 261019986 109892881 109901422 378006845 378110922 239114713 240200555 98023753 98835157 164309315 166050125 366410134 367688305 2150887 32...
output:
YES
result:
ok single line: 'YES'
Test #9:
score: 0
Accepted
time: 534ms
memory: 252180kb
input:
1 100000 100000 11672826 13497531 37847875 38695470 396896787 397288314 41329488 41514311 46702185 46736307 158676605 159765254 10679058 11260139 495295254 496293460 405805072 407370951 266920381 268613253 240967173 242427524 302795628 303149675 161224201 161255535 15952349 17582093 71045574 7273405...
output:
YES
result:
ok single line: 'YES'
Test #10:
score: 0
Accepted
time: 526ms
memory: 251820kb
input:
1 100000 100000 11319879 12165296 321934694 322501941 148133021 148796071 67234711 67372154 473276860 474508386 43692541 44109842 39866725 40783924 231811174 233496934 203647263 205446833 155833917 156579231 87615986 88844493 9497503 10000546 158139087 158390945 8360917 9735881 139940261 141601411 4...
output:
NO
result:
ok single line: 'NO'
Test #11:
score: 0
Accepted
time: 516ms
memory: 250636kb
input:
1 100000 100000 10950125 12051005 477581440 479154681 94266678 95909979 490182390 490895222 94347259 95525774 101284037 102455472 432053547 433727469 8722754 9737212 209620774 210562306 217508613 219120110 344267790 344951284 100795316 101617492 485408060 487219509 113683680 115563586 311623132 3122...
output:
YES
result:
ok single line: 'YES'
Test #12:
score: 0
Accepted
time: 42ms
memory: 8232kb
input:
10 1000 0 9084548 212659299 752049685 757793200 161999637 297780621 159218899 511613241 227411331 728832104 27428018 66692999 70254106 230710848 142218079 695911798 706863260 786626002 164254194 896730741 106307919 803778907 251793390 439950319 141699718 573753059 659066161 997295279 269040766 43188...
output:
YES YES YES YES YES YES YES YES YES YES
result:
ok 10 lines
Test #13:
score: 0
Accepted
time: 364ms
memory: 40304kb
input:
10 10000 10000 8076128 8101663 29809420 29847609 370721525 370740253 892411542 892413288 747565478 747585274 5739499 5751302 227883289 227888911 696243800 696274475 209086262 209139782 153701675 153740284 794914 801208 712815424 712841626 488108468 488120604 546898456 546921288 517871533 517891373 1...
output:
YES YES NO YES YES NO YES NO YES NO
result:
ok 10 lines
Test #14:
score: 0
Accepted
time: 171ms
memory: 18232kb
input:
100 691 691 508569640 508673802 208642094 208647922 28027525 28893278 215521571 216082768 432101881 432674036 287707806 288112166 757429741 757751727 729675214 730370857 359025437 359615838 697602408 698131276 443239285 444206285 186833263 187588090 357750289 357756701 552823963 552982349 527211763 ...
output:
YES NO YES NO YES YES YES YES NO NO NO NO YES NO NO YES YES YES YES YES NO YES YES YES YES NO NO NO YES YES YES NO YES YES YES YES YES NO NO YES YES NO NO NO NO NO YES NO YES YES NO YES NO YES YES NO YES NO NO NO NO YES YES YES YES YES NO NO NO NO NO YES NO NO YES YES NO NO NO YES NO NO NO YES YES N...
result:
ok 100 lines
Test #15:
score: 0
Accepted
time: 564ms
memory: 252172kb
input:
1 50000 50000 235239015 627380255 144730978 542058842 550305498 565415835 328800870 680798359 385148497 675077021 362103943 863384846 59798050 589436710 113699937 487373907 557941848 790625291 60531465 592567224 41157560 245376586 825839343 875678662 159266647 695027240 319681713 822890545 247698126...
output:
NO
result:
ok single line: 'NO'
Test #16:
score: 0
Accepted
time: 557ms
memory: 250752kb
input:
1 50000 50000 626892852 633391382 332519095 895980171 583401233 961674476 352795837 693969388 30261670 447241929 226651863 602336203 583872139 849355310 79235608 858959672 78521707 943110748 724798770 952348869 424887625 958660184 703187100 863080259 555964295 685361175 390557968 397742944 529306351...
output:
NO
result:
ok single line: 'NO'
Test #17:
score: 0
Accepted
time: 1177ms
memory: 458548kb
input:
1 100000 100000 611316630 629811740 91996695 793205603 205568177 975572692 476141394 984340236 739813611 910022525 212513275 370043741 310441153 445307964 319058023 346679908 670565549 934504580 566150142 993981165 932880384 935485719 680278897 980699546 244485251 927396846 322480796 833496991 34107...
output:
YES
result:
ok single line: 'YES'
Test #18:
score: 0
Accepted
time: 1209ms
memory: 458604kb
input:
1 100000 100000 610946876 857807203 599281597 900917088 427496349 598338428 123875625 401019073 847949514 858954010 442677409 578978884 824577876 988838433 63366721 968387841 306867511 438548091 59515861 703179972 536258541 701410706 71997359 819298030 69824224 802640084 4101933 272599912 14689805 7...
output:
YES
result:
ok single line: 'YES'
Test #19:
score: 0
Accepted
time: 1229ms
memory: 458656kb
input:
1 100000 100000 85802666 610577122 405357591 562353834 26903653 991108679 263411014 325896752 638392856 978094409 525357896 640430380 338714599 384885255 590095774 660191772 942591602 943169473 272534204 692726155 139636698 467335693 163295172 810833516 530399675 895163197 174706875 222719028 688302...
output:
NO
result:
ok single line: 'NO'
Test #20:
score: 0
Accepted
time: 1207ms
memory: 458480kb
input:
1 100000 100000 31322880 610190561 373973574 896107801 482202027 913667658 92579172 149746887 638456885 716565783 25801083 640083865 143931232 778608280 96995720 266977967 5352786 562939706 662173707 686213373 905911158 993954199 99239139 137258923 274071980 903372610 88515186 122828692 616047378 68...
output:
YES
result:
ok single line: 'YES'
Test #21:
score: 0
Accepted
time: 1221ms
memory: 458684kb
input:
1 100000 100000 609736772 846942098 34228770 550298572 102865196 803515622 385311112 716970493 53642257 208238815 264397673 588024468 207490182 921529793 292147365 766125091 116583023 745435603 105530143 905781497 409578135 887604888 199435485 837707075 232998371 933911494 85482313 827653326 1178684...
output:
YES
result:
ok single line: 'YES'
Test #22:
score: 0
Accepted
time: 857ms
memory: 64692kb
input:
10 10000 10000 968433817 980345689 103557645 824564023 829074871 997250637 474151154 894114908 716734949 928511820 579435564 960645476 162817 170066 26989283 75787020 330896 456526 312609711 500901739 503200 539839 693994 864159 959375 1027512 482433434 698751890 138723658 154257942 1157115 1278976 ...
output:
YES NO YES YES YES YES NO NO YES YES
result:
ok 10 lines
Test #23:
score: 0
Accepted
time: 812ms
memory: 64264kb
input:
10 10000 10000 55889446 676543761 339486739 512854517 89914 263037 43940346 743378135 474800917 474989262 381945 551085 53729144 521064977 625461 772887 174165490 859237741 895977 913869 122582738 363347004 1002118 1119286 557598499 854847993 1187071 1271634 1342510 1377024 1428419 1571587 1729397 1...
output:
NO YES NO NO NO NO YES NO NO YES
result:
ok 10 lines
Test #24:
score: 0
Accepted
time: 976ms
memory: 446756kb
input:
1 100000 100000 2825612 287187070 999993267 1000000000 94 854 155005964 287573137 9070 21537 26142 34796 44434 45874 56159 63808 991386787 993171553 220122482 731015713 69663 87780 617617555 933500337 169625859 372421698 305623688 808834660 596826732 937822295 100817 108696 649207508 659155127 12219...
output:
YES
result:
ok single line: 'YES'
Test #25:
score: 0
Accepted
time: 912ms
memory: 460784kb
input:
1 100000 100000 3092 15274 19530 26942 33337 41977 627434658 942568814 43029 56667 697630428 961374423 58104 73299 110856530 735851270 82074 88280 141181852 262918400 96630091 650451770 92264 103401 172238029 172249854 388421560 643850618 105442 124096 131664 143119 280179217 333440826 148798 166640...
output:
NO
result:
ok single line: 'NO'
Test #26:
score: 0
Accepted
time: 1024ms
memory: 458668kb
input:
1 100000 100000 10871 20950 37967 48437 285223721 594034432 51008 69067 76789 94787 97482 101557 26805305 26817148 115032 116107 387548524 412427666 129659 148344 38643779 237102119 163617 172021 188640 192596 202853 209871 216178 233816 252619 269075 478290210 592268749 853248909 963217231 282903 2...
output:
NO
result:
ok single line: 'NO'
Test #27:
score: 0
Accepted
time: 999ms
memory: 453548kb
input:
1 100000 100000 12795 27793 28468 41752 806312932 872614132 43181 55491 64694 82276 97343 111737 653273873 653281920 121362 135600 152867 169975 170207 170720 68812492 780071607 824067587 981895206 55248817 646910393 33392751 277269763 398950075 812465043 179090 185948 819483157 819498645 144084780 ...
output:
NO
result:
ok single line: 'NO'
Test #28:
score: 0
Accepted
time: 1007ms
memory: 446524kb
input:
1 100000 100000 10221 14469 186957342 298058745 18743 36956 92950555 865157656 126663217 672393942 401361439 435570046 32239890 128425695 48937043 392849449 145368241 160614779 239539699 794392360 10826180 366721956 39944 40064 59006 60530 23920020 444334151 92172706 705687920 298764881 317566859 17...
output:
YES
result:
ok single line: 'YES'