QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#134883 | #6634. Central Subset | salvator_noster# | TL | 98ms | 24812kb | C++14 | 1.9kb | 2023-08-05 09:43:08 | 2023-08-05 09:43:11 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
const int SZN = 200000 + 5;
const int SZM = 1000000 + 5;
int n, m, bnd;
int ufa[SZN];
vector<int> out[SZN];
int getFa(int u) {
return ufa[u] == u ? u : ufa[u] = getFa(ufa[u]);
}
int getInt(void) {
int ch = getchar(), res = 0;
while (!isdigit(ch)) {
ch = getchar();
}
for (; isdigit(ch); ch = getchar()) {
res = res * 10 + (ch - '0');
}
return res;
}
int vis[SZN];
void mark(int u, int fa, int dep) {
vis[u] = 1;
if (dep < bnd) {
for (int v : out[u]) {
if (v != fa) {
mark(v, u, dep + 1);
}
}
}
return;
}
int dep[SZN], ids[SZN];
bool cmp(int a, int b) {
return dep[a] > dep[b];
}
int fa[SZN];
void dfs(int u) {
for (int v : out[u]) {
if (v != fa[u]) {
dep[v] = dep[u] + 1;
fa[v] = u;
dfs(v);
}
}
return;
}
int main(void) {
int t = getInt();
while (t--) {
n = getInt(), m = getInt();
bnd = sqrt(n);
while ((bnd - 1) * (bnd - 1) >= n) {
--bnd;
}
while (bnd * bnd < n) {
++bnd;
}
for (int i = 1; i <= n; ++i) {
ufa[i] = i;
}
for (int i = 1; i <= m; ++i) {
int u = getInt(), v = getInt();
int uf = getFa(u), vf = getFa(v);
if (uf != vf) {
out[u].push_back(v);
out[v].push_back(u);
ufa[uf] = vf;
}
}
dfs(1);
for (int i = 1; i <= n; ++i) {
vis[i] = 0;
ids[i] = i;
}
sort(ids + 1, ids + n + 1, cmp);
vector<int> ans;
for (int i = 1; i <= n; ++i) {
int u = ids[i];
if (!vis[u]) {
int v = u;
for (int j = 1; j <= bnd && v != 1; ++j) {
v = fa[v];
}
ans.push_back(v);
mark(v, 0, 0);
}
}
if ((int)ans.size() > bnd) {
puts("-1");
} else {
int sz = ans.size();
printf("%d\n", sz);
for (int i = 0; i < sz; ++i) {
printf("%d%c", ans[i], " \n"[i == sz - 1]);
}
}
for (int i = 1; i <= n; ++i) {
out[i].clear();
}
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 2ms
memory: 8736kb
input:
2 4 3 1 2 2 3 3 4 6 7 1 2 2 3 3 1 1 4 4 5 5 6 6 4
output:
1 2 1 1
result:
ok correct (2 test cases)
Test #2:
score: 0
Accepted
time: 12ms
memory: 8916kb
input:
10000 15 14 13 12 5 4 9 8 11 12 15 14 10 9 14 13 2 3 2 1 6 5 10 11 3 4 7 6 8 7 6 5 2 1 2 4 4 6 2 3 3 5 10 9 8 3 9 4 5 6 5 10 3 2 5 4 2 7 1 2 4 3 2 1 2 1 2 1 2 1 9 8 9 8 5 4 1 2 6 5 3 4 3 2 7 8 7 6 2 1 1 2 14 13 3 10 5 6 2 9 11 4 2 3 2 1 8 7 13 6 5 4 5 12 6 7 4 3 7 14 16 15 2 3 2 1 6 10 6 9 6 4 9 11 ...
output:
2 11 2 1 1 1 2 1 1 1 1 2 6 1 1 1 1 4 2 10 1 1 1 2 15 4 1 3 1 2 1 5 1 1 2 11 2 1 1 1 1 1 2 1 1 1 2 1 3 1 4 1 5 1 1 2 11 2 1 1 1 5 1 1 1 1 2 16 5 1 2 1 4 2 7 1 1 1 1 3 1 2 1 3 2 7 6 1 1 2 8 1 1 1 1 3 1 2 1 1 2 6 1 1 3 1 3 1 5 1 1 2 13 2 1 1 1 3 1 4 1 1 2 12 3 1 2 1 2 1 1 1 1 1 2 1 2 1 2 1 2 1 1 2 5 1 ...
result:
ok correct (10000 test cases)
Test #3:
score: 0
Accepted
time: 17ms
memory: 10056kb
input:
100 2000 1999 529 528 885 884 1221 1222 375 374 245 244 758 757 711 710 1521 1522 1875 1874 749 750 823 822 1959 1958 1767 1766 155 154 631 632 825 824 1330 1331 457 456 1344 1343 1817 1818 413 414 582 583 1828 1827 1335 1336 654 655 162 161 1668 1667 1966 1967 1472 1471 1185 1184 518 517 1509 1510 ...
output:
22 1955 1864 1773 1682 1591 1500 1409 1318 1227 1136 1045 954 863 772 681 590 499 408 317 226 135 44 1 1 12 956 867 778 689 600 511 422 333 244 155 66 1 4 1170 1047 107 32 1 1 22 1955 1864 1773 1682 1591 1500 1409 1318 1227 1136 1045 954 863 772 681 590 499 408 317 226 135 44 1 1 12 956 867 778 689 ...
result:
ok correct (100 test cases)
Test #4:
score: 0
Accepted
time: 17ms
memory: 11288kb
input:
10 14914 14913 13959 13958 3643 3642 4582 4581 13378 13379 981 980 12901 12902 12355 12356 14692 14691 9670 9669 14632 14631 1441 1440 1367 1368 6237 6238 8297 8298 1021 1020 5096 5097 4773 4774 7778 7779 3013 3014 5536 5535 11621 11620 13904 13903 3050 3049 14179 14178 7471 7472 13380 13381 7403 74...
output:
61 14791 14544 14297 14050 13803 13556 13309 13062 12815 12568 12321 12074 11827 11580 11333 11086 10839 10592 10345 10098 9851 9604 9357 9110 8863 8616 8369 8122 7875 7628 7381 7134 6887 6640 6393 6146 5899 5652 5405 5158 4911 4664 4417 4170 3923 3676 3429 3182 2935 2688 2441 2194 1947 1700 1453 12...
result:
ok correct (10 test cases)
Test #5:
score: 0
Accepted
time: 30ms
memory: 10804kb
input:
10 20000 19999 6831 6760 15763 15900 10362 10184 5821 5880 17555 17389 16708 16574 11592 11436 186 209 19380 19313 8867 8718 12100 12237 16245 16110 18464 18568 4713 4665 17412 17578 18666 18750 4360 4322 12350 12502 4054 4103 2874 2849 8097 8202 14489 14639 1056 1016 13500 13581 2435 2391 199 173 8...
output:
2 6126 1143 4 10809 8283 176 142 3 11257 8040 471 3 10584 9863 2437 5 15169 14623 6490 5958 1 4 15046 6159 4075 1 4 15985 6581 972 256 4 7843 6192 5415 266 4 14312 1588 1025 27 4 8901 8799 7775 387
result:
ok correct (10 test cases)
Test #6:
score: 0
Accepted
time: 42ms
memory: 24812kb
input:
1 200000 199999 136649 136648 44943 44944 7148 7149 50332 50333 149967 149966 28976 28975 78549 78550 178698 178697 96434 96433 7859 7858 88976 88977 23348 23347 161682 161681 125393 125392 67892 67893 73592 73593 179054 179055 110841 110842 163714 163715 7982 7981 56309 56310 196486 196485 19176 19...
output:
223 199552 198655 197758 196861 195964 195067 194170 193273 192376 191479 190582 189685 188788 187891 186994 186097 185200 184303 183406 182509 181612 180715 179818 178921 178024 177127 176230 175333 174436 173539 172642 171745 170848 169951 169054 168157 167260 166363 165466 164569 163672 162775 16...
result:
ok correct (1 test case)
Test #7:
score: 0
Accepted
time: 68ms
memory: 21732kb
input:
1 200000 199999 58280 58281 132016 32016 45157 45158 35446 35445 158979 58979 185831 85831 74289 174289 195645 95645 31857 131857 168766 68766 95607 95606 39817 39818 58215 158215 74893 74894 18897 118897 63013 163013 58501 58502 94475 194475 77574 77573 152977 52977 3731 103731 20407 20408 186570 8...
output:
112 99553 98658 97763 96868 95973 95078 94183 93288 92393 91498 90603 89708 88813 87918 87023 86128 85233 84338 83443 82548 81653 80758 79863 78968 78073 77178 76283 75388 74493 73598 72703 71808 70913 70018 69123 68228 67333 66438 65543 64648 63753 62858 61963 61068 60173 59278 58383 57488 56593 55...
result:
ok correct (1 test case)
Test #8:
score: 0
Accepted
time: 60ms
memory: 18592kb
input:
1 200000 199999 84088 84001 74829 74679 40726 41179 113019 113238 112813 113025 77336 77177 60908 61208 4521 4639 144249 144094 102763 102692 112856 113070 2428 2356 114005 113754 168454 168270 114538 114311 36802 36341 170182 170306 31641 32012 92503 92395 143570 143702 6871 6715 51503 51997 140883...
output:
3 149019 118805 4044
result:
ok correct (1 test case)
Test #9:
score: 0
Accepted
time: 10ms
memory: 9864kb
input:
1000 11 19 8 11 4 11 2 11 2 3 8 3 6 1 6 4 11 5 5 3 10 8 7 10 4 7 3 9 5 1 5 7 3 6 10 1 11 7 2 9 70 109 32 69 26 15 65 46 70 62 50 23 17 16 15 31 2 23 18 11 48 57 19 29 52 42 26 31 7 1 53 66 5 69 58 20 59 38 3 4 9 53 7 56 52 66 66 28 22 51 2 6 22 35 5 28 25 51 27 13 26 56 10 50 53 56 60 48 67 33 61 23...
output:
1 4 1 66 2 11 1 2 53 1 2 27 42 2 10 1 1 10 1 41 2 40 38 2 31 40 2 15 1 2 88 93 1 1 2 2 1 2 20 1 1 11 1 12 1 1 2 9 43 2 31 1 2 7 16 2 34 1 1 23 2 79 17 2 31 1 1 10 2 26 24 2 6 40 2 30 19 2 2 61 2 23 22 3 4 8 1 2 42 49 2 24 1 2 57 1 2 20 1 2 2 29 2 55 1 1 27 2 25 42 2 2 1 1 26 1 31 2 79 49 2 19 85 1 5...
result:
ok correct (1000 test cases)
Test #10:
score: 0
Accepted
time: 1ms
memory: 10116kb
input:
100 76 104 30 11 26 40 4 59 35 21 13 44 3 73 25 39 33 35 63 9 9 19 42 47 22 32 44 35 74 68 53 12 50 41 53 52 69 40 31 49 21 14 23 21 11 48 53 67 48 74 15 24 73 47 6 62 17 33 67 48 7 22 68 46 41 39 20 1 9 71 15 67 65 56 38 68 30 9 54 26 8 47 62 56 14 61 59 20 46 64 75 46 50 49 26 25 10 70 36 27 14 29...
output:
2 44 57 2 4 1 2 54 42 2 17 34 2 32 44 2 54 40 2 27 1 1 49 2 58 79 1 15 1 80 2 31 82 2 32 1 2 59 1 2 41 13 2 32 1 2 28 1 1 48 2 78 1 3 59 40 1 3 64 6 1 2 55 21 2 50 48 2 20 15 2 2 50 2 11 8 2 15 11 2 52 81 2 39 1 1 31 2 3 1 2 67 1 1 7 2 46 13 2 37 1 2 71 28 2 23 1 3 46 58 80 2 11 18 2 12 1 1 45 1 65 ...
result:
ok correct (100 test cases)
Test #11:
score: 0
Accepted
time: 93ms
memory: 14616kb
input:
1 100000 1000000 70376 68374 69858 95507 48028 59467 27775 34161 858 86059 31468 25048 21313 82671 10952 18093 89665 50624 52742 11128 33566 41507 25913 22268 72131 67543 31387 42274 37347 75248 88261 56182 98982 47735 90574 62875 51228 53905 25218 4567 78201 22017 59613 68982 37239 43727 67620 9064...
output:
1 1
result:
ok correct (1 test case)
Test #12:
score: 0
Accepted
time: 98ms
memory: 22816kb
input:
1 200000 200000 89381 101645 141954 180063 180085 158544 12185 82120 161570 175869 36911 151360 49966 148400 135100 143084 145185 33970 82150 111213 93727 145916 42620 157053 26848 66273 178649 76101 5033 162413 173225 34259 30781 78979 9908 187256 87177 127185 7086 26040 178611 119947 198142 154140...
output:
223 20130 117915 77781 173519 118751 162296 98088 23786 54619 180008 13111 12611 58560 54059 20893 185328 27106 43572 160876 95235 44478 113869 3045 41677 41341 125236 186716 49690 28363 6642 120061 165937 89427 158351 53100 152365 60764 25712 66512 120322 118267 113275 33806 80232 137925 85238 9575...
result:
ok correct (1 test case)
Test #13:
score: -100
Time Limit Exceeded
input:
1 199809 199808 197381 136472 136472 160228 160228 128766 128766 197225 197225 160133 160133 105707 105707 66465 66465 199512 199512 185463 185463 176514 176514 175293 175293 178768 178768 158873 158873 199518 199518 161400 161400 172476 172476 188761 188761 197795 197795 152286 152286 177332 177332...