QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#831068 | #7460. rla1rmdq | liuziao | AC ✓ | 1680ms | 49340kb | C++23 | 4.7kb | 2024-12-25 10:11:09 | 2024-12-25 10:11:09 |
Judging History
answer
#include <bits/stdc++.h>
// #define int int64_t
using i64 = int64_t;
const int kMaxN = 2e5 + 5, kMaxB = 450;
int n, m, b, tot, rt;
int a[kMaxN], p[kMaxN], sz[kMaxN], wson[kMaxN], top[kMaxN], dfn[kMaxN], idx[kMaxN];
int L[kMaxB], R[kMaxB], bel[kMaxN], cnt[kMaxN], id[kMaxB][kMaxB], tag[kMaxB];
i64 dis[kMaxN], res[kMaxB];
std::bitset<kMaxN> vis[kMaxB], in;
std::vector<std::pair<int, int>> G[kMaxN];
void dfs1(int u, int fa) {
p[u] = (!fa ? u : fa);
sz[u] = 1;
for (auto [v, w] : G[u]) {
if (v == fa) continue;
dis[v] = dis[u] + w;
dfs1(v, u);
sz[u] += sz[v];
if (sz[v] > sz[wson[u]]) wson[u] = v;
}
}
void dfs2(int u, int fa, int t) {
static int cnt = 0;
idx[dfn[u] = ++cnt] = u, top[u] = t;
if (wson[u]) dfs2(wson[u], u, t);
for (auto [v, w] : G[u]) {
if (v == fa || v == wson[u]) continue;
dfs2(v, u, v);
}
}
int getfa(int x, int k) {
// std::cerr << x << ' ' << k << '\n';
if (!x || x == rt) return rt;
else if (!k) return x;
else if (dfn[x] - k >= dfn[top[x]]) return idx[dfn[x] - k];
else return getfa(p[top[x]], k - (dfn[x] - dfn[top[x]] + 1));
// for (int i = 1; i <= k; ++i) x = p[x];
// return x;
}
void prework() {
dis[rt] = 1;
dfs1(rt, 0), dfs2(rt, 0, rt);
b = sqrtl(n);
if (!b) b = 1;
tot = (n + b - 1) / b;
for (int i = 1; i <= tot; ++i) {
L[i] = (i - 1) * b + 1, R[i] = std::min(i * b, n);
res[i] = LLONG_MAX;
for (int j = L[i]; j <= R[i]; ++j) {
bel[j] = i, vis[i][a[j]] = 1;
res[i] = std::min(res[i], dis[a[j]]);
id[i][++id[i][0]] = j, in[j] = 1;
}
}
}
void addtag(int x) {
++tag[x];
static int tmp[kMaxN];
int c = 0;
for (int k = 1; k <= id[x][0]; ++k) {
int i = id[x][k];
in[i] = 0;
--cnt[i];
if (a[i] == rt || !vis[x][a[i] = p[a[i]]]) {
vis[x][a[i]] = 1;
tmp[++c] = i, in[i] = 1, res[x] = std::min(res[x], dis[a[i]]);
}
}
id[x][0] = c;
for (int i = 1; i <= c; ++i) id[x][i] = tmp[i];
// for (int i = L[x]; i <= R[x]; ++i) res[x] = std::min(res[x], dis[a[i] = p[a[i]]]);
}
void rebuild(int x) {
for (int i = L[x]; i <= R[x]; ++i) {
assert(tag[x] + cnt[i] >= 0);
if (tag[x] + cnt[i]) {
a[i] = getfa(a[i], tag[x] + cnt[i]);
res[x] = std::min(res[x], dis[a[i]]);
vis[x][a[i]] = 1;
}
cnt[i] = 0;
}
tag[x] = 0;
}
void update(int l, int r) {
int x = bel[l], y = bel[r];
if (x == y) {
for (int i = l; i <= r; ++i) {
a[i] = getfa(a[i], tag[x] + cnt[i] + 1);
res[x] = std::min(res[x], dis[a[i]]);
cnt[i] = -tag[x];
if (!vis[x][a[i]]) {
vis[x][a[i]] = 1;
if (!in[i]) id[x][++id[x][0]] = i, in[i] = 1;
}
}
} else {
// for (int i = l; i <= R[x]; ++i) ++cnt[i];
for (int i = l; i <= R[x]; ++i) {
a[i] = getfa(a[i], tag[x] + cnt[i] + 1);
res[x] = std::min(res[x], dis[a[i]]);
cnt[i] = -tag[x];
if (!vis[x][a[i]]) {
vis[x][a[i]] = 1;
if (!in[i]) id[x][++id[x][0]] = i, in[i] = 1;
}
}
// for (int i = L[y]; i <= r; ++i) ++cnt[i];
for (int i = L[y]; i <= r; ++i) {
a[i] = getfa(a[i], tag[y] + cnt[i] + 1);
res[y] = std::min(res[y], dis[a[i]]);
cnt[i] = -tag[y];
if (!vis[y][a[i]]) {
vis[y][a[i]] = 1;
if (!in[i]) id[y][++id[y][0]] = i, in[i] = 1;
}
}
// rebuild(x), rebuild(y);
for (int i = x + 1; i < y; ++i) addtag(i);
}
}
i64 query(int l, int r) {
int x = bel[l], y = bel[r];
i64 ret = LLONG_MAX;
if (x == y) {
rebuild(x);
for (int i = l; i <= r; ++i) ret = std::min(ret, dis[a[i]]);
return ret;
} else {
rebuild(x), rebuild(y);
for (int i = l; i <= R[x]; ++i) ret = std::min(ret, dis[a[i]]);
for (int i = L[y]; i <= r; ++i) ret = std::min(ret, dis[a[i]]);
for (int i = x + 1; i < y; ++i) ret = std::min(ret, res[i]);
return ret;
}
}
void dickdreamer() {
std::cin >> n >> m >> rt;
for (int i = 1; i < n; ++i) {
int u, v, w;
std::cin >> u >> v >> w;
G[u].emplace_back(v, w), G[v].emplace_back(u, w);
}
for (int i = 1; i <= n; ++i) std::cin >> a[i];
prework();
for (int i = 1; i <= m; ++i) {
int op, l, r;
std::cin >> op >> l >> r;
if (op == 1) {
update(l, r);
} else {
std::cout << query(l, r) - 1 << '\n';
}
}
}
int32_t main() {
#ifdef ORZXKR
freopen("in.txt", "r", stdin);
freopen("out.txt", "w", stdout);
#endif
std::ios::sync_with_stdio(0), std::cin.tie(0), std::cout.tie(0);
int T = 1;
// std::cin >> T;
while (T--) dickdreamer();
// std::cerr << 1.0 * clock() / CLOCKS_PER_SEC << "s\n";
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 4ms
memory: 18000kb
input:
1000 1000 30 387 326 122462824 887 387 562582179 887 654 770128125 654 328 221541327 434 328 2553348 434 491 157302072 995 491 633483200 159 995 340185596 341 159 247406423 341 374 34719360 374 842 176004272 418 842 437086650 762 418 74356113 458 762 58888544 458 1 34594098 756 1 162123720 756 300 2...
output:
0 0 0 59618405 0 109474754 927219514 0 0 0 0 0 0 0 0 0 0 0 0 0 1121629595 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 32898230518 0 0 0 0 109474754 0 1798768018 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0...
result:
ok 531 numbers
Test #2:
score: 0
Accepted
time: 0ms
memory: 18056kb
input:
1000 1000 72 538 232 92 538 208 564 309 208 334 538 7 807 50 309 502 232 614 84 637 232 225 614 596 999 538 738 457 616 596 404 566 309 48 309 238 89 697 614 554 637 713 778 151 7 500 538 680 570 998 538 649 637 455 757 48 566 860 82 738 642 2 616 491 238 433 299 342 82 510 238 318 48 219 238 94 207...
output:
696 696 1159 0 696 0 0 0 0 1330 0 0 0 1595 0 0 0 0 696 0 0 0 696 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0...
result:
ok 457 numbers
Test #3:
score: 0
Accepted
time: 617ms
memory: 37708kb
input:
200000 200000 6173 198188 168337 1 199878 168337 1 176719 198188 1 192955 176719 1 180639 199878 1 191536 192955 1 189369 180639 1 176719 117715 1 198188 183505 1 168337 166518 1 193620 199878 1 191536 190998 1 170250 183505 1 166518 139758 1 185126 198188 1 139758 197741 1 193620 198063 1 196236 18...
output:
0 0 0 2 2 0 3 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...
result:
ok 99979 numbers
Test #4:
score: 0
Accepted
time: 1598ms
memory: 41524kb
input:
200000 200000 8329 190404 173256 1 190404 139279 1 178966 173256 1 178966 194546 1 194546 179636 1 178966 187886 1 187886 197598 1 187886 193440 1 143498 187886 1 194318 193440 1 199916 143498 1 149195 199916 1 149195 178505 1 198691 149195 1 178505 196502 1 198691 104714 1 198691 177305 1 177240 10...
output:
23348 23348 23346 23346 23346 23345 23346 23347 23344 23344 23344 23344 23345 23345 23345 23343 23341 23345 23346 23341 23341 23346 23335 23335 23334 23337 23339 23338 23335 23333 23333 23333 23337 23333 23336 23336 23335 23337 23338 23331 23338 23331 23330 23331 23330 23330 23329 23327 23327 23327 ...
result:
ok 100295 numbers
Test #5:
score: 0
Accepted
time: 840ms
memory: 37048kb
input:
200000 200000 21084 188105 178955 1 190655 188105 1 191517 188105 1 188105 173814 1 188105 180592 1 181783 188105 1 178955 162502 1 157871 188105 1 188623 181783 1 194914 162502 1 190655 191573 1 181783 173064 1 188105 194536 1 191517 190243 1 188105 183228 1 195145 162502 1 181783 171491 1 168262 1...
output:
4120 4120 4119 4118 4117 4118 4119 4117 4117 4115 4114 4116 4112 4112 4112 4112 4111 4107 4111 4113 4111 4107 4107 4109 4108 4107 4106 4108 4106 4106 4105 4105 4103 4103 4106 4103 4103 4104 4101 4099 4098 4098 4101 4096 4094 4094 4100 4092 4095 4091 4106 4097 4096 4091 4093 4097 4091 4103 4090 4088 ...
result:
ok 100291 numbers
Test #6:
score: 0
Accepted
time: 756ms
memory: 35568kb
input:
200000 200000 195598 98825 195598 472564603 195326 195598 148190665 179136 195598 465687866 182322 195598 668538483 161178 195598 665231285 164557 195598 237353256 199026 195598 976182211 199424 195598 102216460 189354 195598 410290482 170314 195598 601542607 170253 195598 282233521 174871 195598 13...
output:
180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 180589315639 1...
result:
ok 198985 numbers
Test #7:
score: 0
Accepted
time: 669ms
memory: 35748kb
input:
200000 200000 189564 199622 189564 369725840 158674 189564 704657456 148589 189564 238609597 181464 189564 156322841 183583 189564 29858778 174113 189564 137092992 192435 189564 117708105 174914 189564 822549875 164580 189564 753621481 177082 189564 339223335 174111 189564 43202106 182554 189564 638...
output:
69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69505499669 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 69373956908 ...
result:
ok 196696 numbers
Test #8:
score: 0
Accepted
time: 763ms
memory: 36076kb
input:
200000 200000 159638 191187 159638 625863988 144089 159638 341855616 193360 159638 125684629 172320 159638 353656611 171783 159638 161413264 154375 159638 20108819 199256 159638 915823059 191700 159638 388224732 185641 159638 751745496 187383 159638 476441942 141683 159638 35879066 46536 159638 8107...
output:
180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 180237323780 179628325663 179628325663 179628325663 179628325663 1...
result:
ok 196608 numbers
Test #9:
score: 0
Accepted
time: 776ms
memory: 39116kb
input:
200000 200000 157857 180089 157857 10410 153812 180089 9113 193874 153812 30243 14719 193874 17605 182997 14719 18657 172011 182997 8209 186793 172011 22264 194557 186793 5069 171500 194557 9705 114293 171500 11043 87574 114293 16582 176670 87574 9560 168832 176670 6551 168717 168832 591 185477 1687...
output:
304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 304218478 ...
result:
ok 195912 numbers
Test #10:
score: 0
Accepted
time: 535ms
memory: 35496kb
input:
200000 200000 157876 165371 157876 8322 120682 165371 7802 191807 120682 16401 144738 191807 13201 133801 144738 14474 171871 133801 16651 118275 171871 21946 197590 118275 7090 157982 197590 4687 183675 157982 4172 164262 183675 736 167519 164262 18112 193961 167519 29230 180167 193961 24699 165821...
output:
207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 207144032 ...
result:
ok 199032 numbers
Test #11:
score: 0
Accepted
time: 760ms
memory: 37504kb
input:
200000 200000 144312 158595 144312 22870 136773 158595 13922 199957 136773 21408 162537 199957 25980 123948 162537 32523 199095 123948 204 199708 199095 19127 136157 199708 13193 190702 136157 6062 177008 190702 9271 183614 177008 26300 195054 183614 12574 191157 195054 6273 135018 191157 20730 1873...
output:
290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 290156147 214544995 214544995 214544995 214544995 214544995 214544995 214544995 214544995 214544995 214544995 214544995 ...
result:
ok 195993 numbers
Test #12:
score: 0
Accepted
time: 1674ms
memory: 35584kb
input:
200000 200000 192380 179892 192380 784836449 197288 192380 548173142 186422 192380 674765097 126589 192380 400845214 174301 192380 171434490 175726 192380 328874410 179383 192380 261444846 176902 192380 140457714 192774 192380 256729269 196074 192380 828531480 196092 192380 751541631 93905 192380 31...
output:
2781676238886 2781676238886 2781676238886 2781676238886 2781676238886 2781676238886 2781676238886 2781676238886 2781676238886 2781676238886 2780974847208 2780974847208 2780974847208 2780974847208 2780974847208 2780974847208 2780974847208 2780974847208 2780974847208 2780213390568 2780974847208 278021...
result:
ok 192041 numbers
Test #13:
score: 0
Accepted
time: 1680ms
memory: 45440kb
input:
200000 200000 154485 191570 154485 980594532 175995 191570 427442349 186678 175995 822444069 194440 186678 348492988 178606 194440 478820422 182339 178606 163162661 166187 182339 25774399 164467 166187 601900450 167113 164467 394466605 182185 167113 816705963 172513 182185 578956732 196154 172513 17...
output:
42238775404125 42239536909624 42238775404125 42239161412201 42238712582229 42238712582229 42238032505492 42237498627910 42237498627910 42237091886401 42237091886401 42237091886401 42236191690440 42236247391953 42235710308874 42234443545848 42234443545848 42233395163856 42234929068673 42233395163856 ...
result:
ok 66547 numbers
Test #14:
score: 0
Accepted
time: 895ms
memory: 35324kb
input:
200000 200000 174072 161295 174072 550840997 187792 174072 375590240 171877 174072 452047008 152632 174072 30052772 193836 174072 211687655 175731 174072 773429616 167371 174072 542113430 170965 174072 976920112 118585 174072 632910836 184703 174072 529631736 199825 174072 39102250 181199 174072 627...
output:
767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 767337576869 7...
result:
ok 196621 numbers
Test #15:
score: 0
Accepted
time: 855ms
memory: 36844kb
input:
200000 200000 175774 185743 175774 613941869 171707 185743 72195748 192442 171707 294927032 132593 192442 541656267 182220 132593 537200060 193154 182220 809387143 179328 193154 134901963 196790 179328 576466239 188905 196790 113924622 156015 188905 654065129 141288 156015 705061815 149555 141288 68...
output:
4577977686565 4577977686565 4577977686565 4577055155303 4576921150725 4576880966500 4576880966500 4576880966500 4576921150725 4575377178042 4575233512570 4575143944363 4575357752938 4576880966500 4572245745101 4572904475283 4572245745101 4573090300994 4569260587509 4572904475283 4569260587509 456926...
result:
ok 66712 numbers
Test #16:
score: 0
Accepted
time: 968ms
memory: 42892kb
input:
200000 200000 19748 141704 178011 62448689 153466 141704 406000526 153466 198948 239277382 110708 198948 432312839 190801 110708 93308113 189632 190801 4133198 49968 189632 172016773 49968 195374 48036858 196600 195374 291887961 196600 159556 243683716 159556 171837 12789917 171837 171225 71776765 1...
output:
22504497456931 22504497456930 22503914976053 22503263593391 22503119860190 22503119860190 22503057002069 22501904494856 22501904494856 22501837048287 22500016588081 22499535313940 22499491754782 22498936735771 22498936735771 22498358925237 22498358925237 22498358925237 22497936741053 22497936741053 ...
result:
ok 99953 numbers
Test #17:
score: 0
Accepted
time: 1514ms
memory: 49340kb
input:
200000 200000 19979 185212 198405 411393815 197907 185212 821254769 197907 133192 26822693 162569 133192 13214991 143999 162569 529385289 143999 182047 494735410 194588 182047 325992535 194588 183590 216906471 183590 177348 880736896 131605 177348 425260771 131605 190543 376560298 188506 190543 6696...
output:
40070038057723 40066639490919 40064190274820 40056788070761 40047807435292 40042696657745 40029329321059 40019291516537 40019074704776 40018976048151 40008927994936 40007611799949 40007611799949 40006432193616 39995881442958 39993320342881 39990055264308 39989328905027 39965522142226 39965522142226 ...
result:
ok 9910 numbers
Test #18:
score: 0
Accepted
time: 1502ms
memory: 48344kb
input:
200000 200000 24982 179150 193274 2 193274 173873 5 173873 185107 6 185107 194737 9 105494 194737 9 161515 105494 3 161515 183218 6 183218 189507 2 69064 189507 8 69064 195167 6 166530 195167 2 85320 166530 5 85320 146722 5 146722 198813 3 187396 198813 1 187396 159630 5 162817 159630 1 162817 18735...
output:
668846 668771 668750 668716 668453 668391 668334 668190 668116 668072 668050 668037 667871 667768 667614 667614 667549 667435 667364 667339 667224 667206 667191 667188 667117 667083 667018 666978 666947 666864 666704 666545 666460 666392 666386 666369 666138 666036 666036 666021 665936 665923 665866...
result:
ok 9994 numbers
Test #19:
score: 0
Accepted
time: 1408ms
memory: 44860kb
input:
200000 200000 25035 195112 166019 85 166019 193888 57 148643 193888 49 148643 86491 31 86491 120354 17 169991 120354 43 169991 178101 10 178101 191273 60 191273 176974 53 176974 158353 6 122586 158353 21 175391 122586 21 154449 175391 84 154449 161000 89 161000 185392 23 185392 89860 21 192426 89860...
output:
5069376 5069008 5068074 5067696 5065854 5065611 5063329 5063185 5062570 5062490 5062265 5061295 5061295 5061093 5060719 5060315 5060166 5059772 5058787 5056954 5055322 5054529 5053715 5052417 5051519 5049756 5046882 5045057 5042774 5041252 5034942 5032590 5032439 5032245 5029501 5029455 5028947 5028...
result:
ok 10126 numbers
Test #20:
score: 0
Accepted
time: 1452ms
memory: 46176kb
input:
200000 200000 25067 197050 171421 1 197050 186622 1 186622 185422 1 198809 185422 1 151721 198809 1 151721 184052 1 125949 184052 1 125949 197820 1 197820 198140 1 198140 180602 1 169037 180602 1 128101 169037 1 128101 171095 1 183037 171095 1 183037 189699 1 189489 189699 1 185906 189489 1 185906 1...
output:
119953 119913 119888 119883 119883 119855 119829 119795 119794 119791 119791 119753 119736 119729 119716 119711 119699 119673 119667 119658 119631 119626 119588 119583 119578 119548 119524 119508 119491 119463 119452 119435 119435 119392 119391 119389 119303 119281 119268 119248 119203 119194 119193...
result:
ok 9919 numbers