QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#352586 | #4427. Epidemic | ucup-team1209# | AC ✓ | 3061ms | 499004kb | C++20 | 3.1kb | 2024-03-13 13:33:23 | 2024-03-13 13:33:24 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define cs const
#define pb push_back
cs int N = 1e6 + 5, M = 3e6 + 5;
int T;
int n, m, nd, c[M], las[M];
set <int> pos; // posible positive
set <int> in[M], out[M];
int vis[M];
int shift;
void clear() {
pos.clear();
shift = 0;
for(int i = 0; i <= nd; i++){
in[i].clear();
out[i].clear();
vis[i] = 0;
c[i] = 0;
}
for(int i = 0; i <= n; i++) {
las[i] = 0;
}
}
void add(int x, int y) {
out[x].insert(y);
in[y].insert(x);
}
int decode(int x) {
return (x - 1 + shift) % n + 1;
}
void era_pos(int c) {
if(pos.find(c) != pos.end())
pos.erase(pos.find(c));
}
void era(int x) {
if(c[x] && x == las[c[x]]) era_pos(c[x]);
for(auto v : out[x]) {
assert(in[v].find(x) != in[v].end());
in[v].erase(in[v].find(x));
if(in[v].size() == 0) era(v);
}
out[x].clear();
}
bool neg(int x) {
return pos.find(x) == pos.end();
}
void Main() {
cin >> n >> m;
for(int i = 1; i <= n; i++) pos.insert(i);
nd = n;
for(int i = 1; i <= n; i++) c[i] = las[i] = i;
for(int i = 1; i <= m; i++) {
string op;
int p;
cin >> op >> p;
if(op[0] == 'K') {
vector <int> s;
bool flag = 1;
for(int j = 1; j <= p; j++) {
int x;
cin >> x;
x = decode(x);
s.pb(x);
flag &= neg(x);
}
if(!flag) {
int y = ++ nd;
for(int x : s) {
if(!neg(x)) add(las[x], y);
c[++ nd] = x;
add(y, nd);
las[x] = nd;
pos.insert(x);
}
}
}
if(op[0] == 'P') {
p = decode(p);
era_pos(p);
}
if(op[0] == 'N') {
p = decode(p);
queue <int> q;
q.push(las[p]);
while(!q.empty()) {
int x = q.front(); q.pop();
era(x);
for(auto z : in[x]) {
if(!vis[z]) {
vis[z] = 1;
q.push(z);
}
}
}
}
if(op[0] == 'Q') {
p = decode(p);
auto z = pos.lower_bound(p);
if(z != pos.end()) {
shift = *z;
}
else if(pos.size()) {
shift = *pos.begin();
}
else shift = 0;
if(shift) {
cout << "NIE " << shift << '\n';
}
else {
cout << "TAK\n";
}
}
// for(int x : pos) cout << x << ' '; cout << endl;
}
}
int main() {
#ifdef zqj
freopen("1.in","r",stdin);
#endif
ios :: sync_with_stdio(0), cin.tie(0);
cin >> T;
while(T--) Main(), clear();
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1818ms
memory: 330168kb
input:
5 100000 200000 K 87364 15686 92170 35439 66887 86777 14031 15309 28211 31250 42379 63714 84485 54399 89989 1904 13771 69090 65325 5301 49444 20135 60338 83926 69802 74082 94806 76677 96397 45310 95387 99242 17074 24563 92002 17501 80608 49242 17460 15024 82406 66086 44804 76674 81286 39612 80373 25...
output:
NIE 53312 NIE 39185 NIE 78351 NIE 95331 NIE 79209 NIE 33801 NIE 51733 NIE 76676 NIE 35219 NIE 80600 NIE 79771 NIE 58897 NIE 55869 NIE 75798 NIE 39279 NIE 89805 NIE 97214 NIE 85040 NIE 51997 NIE 64521 NIE 89567 NIE 17181 NIE 41815 NIE 29936 NIE 37055 NIE 57874 NIE 86535 NIE 19194 NIE 54627 NIE 75238 ...
result:
ok 500000 lines
Test #2:
score: 0
Accepted
time: 3029ms
memory: 411744kb
input:
1 500000 1000000 N 481744 Q 450025 N 55611 Q 122541 N 311121 Q 463654 N 385525 Q 437301 N 349043 Q 348074 K 487138 141126 175795 314408 270737 144112 42745 235955 119535 348883 312426 489800 211026 471001 174467 481954 458008 445242 434663 164648 68414 214512 268851 425765 422096 38347 78557 367491 ...
output:
NIE 450025 NIE 72566 NIE 36220 NIE 473521 NIE 321595 NIE 144933 NIE 9184 NIE 82088 NIE 498175 NIE 305892 NIE 101761 NIE 259248 NIE 19122 NIE 352554 NIE 463226 NIE 163114 NIE 39184 NIE 329766 NIE 155161 NIE 143793 NIE 431176 NIE 474442 NIE 465706 NIE 315051 NIE 423430 NIE 24057 NIE 91520 NIE 421905 N...
result:
ok 500000 lines
Test #3:
score: 0
Accepted
time: 518ms
memory: 320012kb
input:
1 500000 1000000 K 2 1 2 Q 1 K 2 1 2 Q 500000 K 2 2 3 Q 500000 K 2 3 4 Q 500000 K 2 4 5 Q 500000 K 2 5 6 Q 500000 K 2 6 7 Q 500000 K 2 7 8 Q 500000 K 2 8 9 Q 500000 K 2 9 10 Q 500000 K 2 10 11 Q 500000 K 2 11 12 Q 500000 K 2 12 13 Q 500000 K 2 13 14 Q 500000 K 2 14 15 Q 500000 K 2 15 16 Q 500000 K 2...
output:
NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 ...
result:
ok 500000 lines
Test #4:
score: 0
Accepted
time: 320ms
memory: 288568kb
input:
1 40000 1000000 K 2 11095 11120 Q 33358 K 2 8755 8762 Q 9002 K 2 38068 38080 Q 12904 N 39506 Q 33194 K 2 28493 28502 Q 30836 N 27400 Q 32926 K 2 6947 6980 Q 5502 K 2 25544 25558 Q 21601 N 19052 Q 21385 K 2 33719 33732 Q 7428 K 2 21560 21584 Q 35262 N 3629 Q 33491 K 2 9285 9311 Q 12571 N 31142 Q 39 K...
output:
NIE 33358 NIE 2360 NIE 15264 NIE 8458 NIE 39294 NIE 32220 NIE 37722 NIE 19323 NIE 708 NIE 8136 NIE 3398 NIE 36889 NIE 9460 NIE 9499 NIE 1918 NIE 10792 NIE 5406 NIE 11836 NIE 24715 NIE 32264 NIE 26042 NIE 133 NIE 12526 NIE 6331 NIE 10548 NIE 32772 NIE 2048 NIE 32879 NIE 12451 NIE 35616 NIE 26704 NIE ...
result:
ok 500000 lines
Test #5:
score: 0
Accepted
time: 720ms
memory: 350068kb
input:
1 140000 979994 K 2 69999 139998 Q 1 K 2 69997 139996 Q 140000 K 2 69996 139995 Q 140000 K 2 69995 139994 Q 140000 K 2 69994 139993 Q 140000 K 2 69993 139992 Q 140000 K 2 69992 139991 Q 140000 K 2 69991 139990 Q 140000 K 2 69990 139989 Q 140000 K 2 69989 139988 Q 140000 K 2 69988 139987 Q 140000 K 2...
output:
NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 ...
result:
ok 489997 lines
Test #6:
score: 0
Accepted
time: 863ms
memory: 462608kb
input:
1 500000 999998 K 2 249999 499998 Q 1 K 2 249997 499996 Q 500000 K 2 249996 499995 Q 500000 K 2 249995 499994 Q 500000 K 2 249994 499993 Q 500000 K 2 249993 499992 Q 500000 K 2 249992 499991 Q 500000 K 2 249991 499990 Q 500000 K 2 249990 499989 Q 500000 K 2 249989 499988 Q 500000 K 2 249988 499987 Q...
output:
NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 NIE 1 ...
result:
ok 499999 lines
Test #7:
score: 0
Accepted
time: 3061ms
memory: 499004kb
input:
1 500000 1000000 K 491799 259367 335786 265921 117853 378964 440906 184265 260415 290117 129200 300375 136031 238493 297634 314963 183227 1150 331313 270230 288631 281365 245188 233219 57629 96117 5486 235536 16616 266024 450500 463810 225869 347163 85799 35785 323592 367376 493928 412335 210444 239...
output:
NIE 489908 NIE 423740 NIE 279006 NIE 462259 NIE 158247 NIE 384378 NIE 494514 NIE 3322 NIE 394683 NIE 442060 NIE 245116 NIE 61703 NIE 252924 NIE 497622 NIE 276108 NIE 220393 NIE 172468 NIE 125805 NIE 222199 NIE 405766 NIE 189316 NIE 448579 NIE 182682 NIE 434642 NIE 107813 NIE 422260 NIE 130090 NIE 10...
result:
ok 500000 lines
Test #8:
score: 0
Accepted
time: 1894ms
memory: 327624kb
input:
5 100000 200000 N 32553 Q 53905 N 99868 Q 16231 N 80193 Q 75322 N 67918 Q 41105 P 1971 Q 19163 N 72688 Q 64285 N 24036 Q 90510 K 42768 9252 90253 81453 25374 20844 19710 87660 25990 26017 14307 47718 33452 44718 78182 80625 34167 31645 17705 54959 79160 13271 86156 74307 11060 41341 6703 47590 90648...
output:
NIE 53905 NIE 70136 NIE 45458 NIE 86563 NIE 5726 NIE 70011 NIE 60521 NIE 18953 NIE 30216 NIE 23898 NIE 24356 NIE 40535 NIE 45637 NIE 40881 NIE 82653 NIE 49596 NIE 50319 NIE 52877 NIE 6746 NIE 47772 NIE 45466 NIE 15691 NIE 77214 NIE 85013 NIE 8550 NIE 84875 NIE 29111 NIE 81603 NIE 12614 NIE 58199 NIE...
result:
ok 500000 lines
Test #9:
score: 0
Accepted
time: 527ms
memory: 290896kb
input:
1000 6 14 K 3 3 4 5 K 2 6 5 N 3 Q 3 P 1 K 2 6 2 P 6 Q 4 P 6 K 2 1 3 N 3 Q 4 N 2 Q 1 5 80 K 5 5 2 3 1 4 Q 1 N 3 Q 3 K 5 3 1 5 2 4 Q 4 K 5 3 4 2 5 1 Q 1 N 1 Q 1 N 4 Q 2 N 5 Q 2 K 5 3 2 5 4 1 Q 5 K 4 2 3 1 5 Q 3 N 1 Q 3 K 2 3 5 Q 2 N 1 Q 5 N 4 Q 1 K 3 5 3 4 Q 3 K 2 2 4 Q 2 K 4 5 2 3 4 Q 5 K 2 5 2 Q 2 N...
output:
NIE 5 NIE 1 TAK TAK NIE 1 TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK NIE 4 NIE 3 NIE 4 NIE 3 NIE 5 TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK TAK ...
result:
ok 496244 lines
Extra Test:
score: 0
Extra Test Passed