QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#728477 | #9416. Intersection of Paths | Moyou | AC ✓ | 1317ms | 266512kb | C++14 | 5.0kb | 2024-11-09 15:15:31 | 2024-11-09 15:15:37 |
Judging History
answer
#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
#include <string>
#define int long long
#define x first
#define y second
using namespace std;
typedef long long ll;
typedef pair<int, ll> PII;
const int N = 5e5 + 10, M = N * 4;
int n, m, pos[N];
basic_string<PII> g[N];
int dep[N], idx, dfn[N], tot;
int root, sz[N], mx;
ll wdep[N], ans[N];
inline char get_char() {
static char buf[1 << 21], *p1 = buf, *p2 = buf;
return p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1 << 21, stdin), p1 == p2) ? EOF : *p1++;
}
inline ll read() {
ll x = 0;
int f = 1;
char ch = get_char();
while (!isalnum(ch)) (ch == '-' ? f = -1 : 1), ch = get_char();
while (isalnum(ch)) x = (x << 1) + (x << 3) + (ch ^ 48), ch = get_char();
return x * f;
}
void write(ll x) {
if (x < 0) putchar('-'), x = -x;
if (x >= 10) write(x / 10);
putchar(x % 10 + '0');
return;
}
bool st[N];
namespace lca {
int timestamp, st[19][N], lg[N];
void dfs(int u, int ft) {
dfn[u] = ++ timestamp, pos[timestamp] = u, st[0][dfn[u]] = ft, sz[u] = 1;
for(auto v : g[u]) if(v.x != ft) dep[v.x] = dep[u] + 1, wdep[v.x] = wdep[u] + v.y, dfs(v.x, u), sz[u] += sz[v.x];
}
int Min(int a, int b) {return dfn[a] < dfn[b] ? a : b;}
void ST() {
for(int i = 1; i <= lg[n]; i ++)
for(int j = 1; j + (1 << i) - 1 <= n; j ++)
st[i][j] = Min(st[i - 1][j], st[i - 1][j + (1 << i - 1)]);
}
int LCA(int l, int r) {
if(l == r) return l;
if((l = dfn[l]) > (r = dfn[r])) swap(l, r);
int k = lg[r - l];
return Min(st[k][l + 1], st[k][r - (1 << k) + 1]);
}
} ;
ll dist(int a, int b) {
return wdep[a] + wdep[b] - 2ll * wdep[lca::LCA(a, b)];
}
int tmp[4];
struct qwq {
int a, b;
qwq () {a = b = 0;}
qwq (int x, int y) {a = x, b = y; }
qwq operator + (const qwq &W) const {
if(!a) return W;
if(!W.a) return qwq(a, b);
tmp[0] = a, tmp[1] = b, tmp[2] = W.a, tmp[3] = W.b;
int ii = -1, jj = -1;
ll mx = -4e18;
for(int i = 0; i < 4; i ++) for(int j = i + 1; j < 4; j ++) {
if(tmp[i] == tmp[j]) continue;
if(dist(tmp[i], tmp[j]) > mx) mx = dist(tmp[i], tmp[j]), ii = i, jj = j;
}
return {tmp[ii], tmp[jj]};
}
} dat[M];
inline void up(int u) {
dat[u] = dat[u << 1] + dat[u << 1 | 1];
}
void build(int u, int l, int r) {
if(l == r) return dat[u] = qwq(0, 0), void();
int mid = l + r >> 1;
build(u << 1, l, mid), build(u << 1 | 1, mid + 1, r), up(u);
}
void update(int u, int l, int r, int x, int v) {
if(l == r) return (v ? dat[u] = (qwq){pos[l], pos[l]} : dat[u] = qwq(0, 0)), void();
int mid = l + r >> 1;
if(x <= mid) update(u << 1, l, mid, x, v);
else update(u << 1 | 1, mid + 1, r, x, v);
return up(u);
}
qwq query(int u, int l, int r, int ql, int qr) {
if(ql > qr) return qwq(0, 0);
if(ql <= l && qr >= r) return dat[u];
int mid = l + r >> 1;
if(ql <= mid && qr > mid) return query(u << 1, l, mid, ql, qr) + query(u << 1 | 1, mid + 1, r, ql, qr);
if(ql <= mid) return query(u << 1, l, mid, ql, qr);
return query(u << 1 | 1, mid + 1, r, ql, qr);
}
void findr(int u, int ft) {
sz[u] = 1;
int maxs = 0;
for(auto v : g[u]) {
if(v.x == ft) continue;
findr(v.x, u), maxs = max(maxs, sz[v.x]), sz[u] += sz[v.x];
}
if(max(maxs, n - sz[u]) < mx) mx = max(maxs, n - sz[u]), root = u;
}
struct E {
int u, v, w;
};
struct owo {
int a, b, k, id;
};
E e[N];
owo q[N];
vector<int> t[N];
vector<owo> qr[N];
void work() {
mx = 1e18;
n = read(), m = read();
for(int i = 1, a, b, c; i < n; i ++) {
a = read(), b = read(), c = read(), g[a].push_back({b, c}), g[b].push_back({a, c});
e[i] = {a, b, c};
}
for(int i = 1; i <= m; i ++)
q[i].a = read(), q[i].b = read(), q[i].k = read(), q[i].id = i, qr[q[i].k].push_back(q[i]);
findr(1, 0);
memset(sz, 0, sizeof sz);
lca::dfs(root, 0), lca::ST();
for(int i = 1; i < n; i ++) {
if(dfn[e[i].u] < dfn[e[i].v]) swap(e[i].u, e[i].v);
t[sz[e[i].u]].push_back(i);
}
build(1, 1, n);
update(1, 1, n, dfn[root], 1);
for(int k = n; k; k --) {
for(auto o : t[k]) {
st[o] = 1;
// cout << k << ' ' << o << ' ' << e[o].u << '\n';
update(1, 1, n, dfn[e[o].u], 1);
}
for(auto o : qr[k]) {
// cout <<"QR "<< k << ' ' << o.id << '\n';
if(!st[o.a]) {
auto t = query(1, 1, n, 1, n);
ans[o.id] = dist(t.a, t.b);
}
else {
int u = e[o.a].u, v = e[o.a].v, w = o.b;
auto out = query(1, 1, n, 1, dfn[u] - 1) + query(1, 1, n, dfn[u] + sz[u], n);
auto in = query(1, 1, n, dfn[u], dfn[u] + sz[u] - 1);
// cout << "DIAM "<< out.a << ' ' << out.b << ' ' << in.a << ' ' << in.b << '\n';
ans[o.id] = max(dist(out.a, out.b), dist(in.a, in.b));
int d1 = dist(out.a, v), d2 = dist(out.b, v), d3 = dist(u, in.a), d4 = dist(u, in.b);
// cout << d1 << ' ' << d2 << ' ' << d3 << ' ' << d4 << '\n';
ans[o.id] = max(max(d1, d2) + max(d3, d4) + w, ans[o.id]);
}
}
}
for(int i = 1; i <= m; i ++) cout << ans[i] << '\n';
}
signed main() {
for(int i = 2; i < N; i ++) lca::lg[i] = lca::lg[i >> 1] + 1;
work();
return 0;
}
这程序好像有点Bug,我给组数据试试?
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 3ms
memory: 96904kb
input:
7 3 1 2 20 2 3 10 2 4 40 4 6 10 1 5 30 5 7 10 2 100 1 5 50 2 2 100 3
output:
160 110 20
result:
ok 3 lines
Test #2:
score: 0
Accepted
time: 8ms
memory: 105356kb
input:
200 500 124 178 427099307 158 192 319431399 117 104 710101310 194 96 839101283 136 4 101584313 105 185 76238080 84 121 653168782 143 136 831330689 147 53 258107910 183 161 822725527 171 165 701914427 127 83 753685257 94 167 437105834 41 173 974941718 33 54 850655642 140 32 414784060 40 24 166931598 ...
output:
4662267167 6250994729 4662267167 0 9861651445 0 0 2874455352 1871656394 1444557087 4662267167 1444557087 6250994729 5898042200 5898042200 0 1444557087 2155191170 1444557087 1444557087 649122524 1444557087 0 5715608407 649122524 0 1444557087 5715608407 0 2874455352 649122524 0 0 6585664630 5898042200...
result:
ok 500 lines
Test #3:
score: 0
Accepted
time: 4ms
memory: 107920kb
input:
200 500 112 128 943053618 196 10 109992136 92 19 372527046 193 51 8504187 111 176 997847081 64 7 511677289 87 64 59358634 92 121 204355409 33 122 426611600 19 28 382475107 113 187 928826711 68 64 914241911 133 40 791046827 8 193 140839139 155 38 35149576 166 82 350823876 139 151 293902264 148 41 921...
output:
8195272055 18038155199 18015634184 6114250165 10575951438 6114250165 13052879291 7036092739 0 13052879291 6077290338 2194906169 12123675487 0 3064424495 3934400794 19314790986 7036092739 0 8706949344 7036092739 11130725173 0 13052879291 0 12123675487 3934400794 3934006014 6553353146 6077290338 12123...
result:
ok 500 lines
Test #4:
score: 0
Accepted
time: 3ms
memory: 107144kb
input:
200 500 30 4 813691610 84 120 817637491 88 111 663721050 5 72 404108850 70 36 348963382 150 134 45804645 188 158 37935708 169 16 882040499 80 12 694412572 97 170 811712290 127 38 9501854 128 115 389754928 75 192 597486526 133 193 975891833 41 100 780943771 161 142 197395217 50 21 884175932 83 84 995...
output:
22172546870 52354768762 27703719679 20639364056 40927307908 14352624650 13315172638 14352624650 42670461106 39281433571 21716516085 50064335349 40927307908 45161769836 33491991214 45263858848 43550274975 26858825538 51968402130 24594720223 46510771787 25974649606 3468011441 55153680913 2278040758 54...
result:
ok 500 lines
Test #5:
score: 0
Accepted
time: 8ms
memory: 107744kb
input:
200 500 50 185 630130276 185 90 932042903 6 187 368883288 14 103 932774738 145 93 183033691 132 60 234965135 184 80 467923508 103 166 358970344 61 98 647414179 9 2 588228845 168 93 442821577 100 61 992122892 60 187 290721521 184 68 552742642 25 38 68998047 13 1 870165451 58 60 931574059 60 125 20953...
output:
0 0 785362711 0 0 0 0 0 0 0 0 1719788928 0 0 0 785362711 1719788928 0 0 0 1531836478 0 3536428150 0 0 0 0 1531836478 0 1583664077 0 0 0 1531836478 2714881481 785362711 0 0 0 0 0 1719788928 1719788928 1583664077 0 1873786210 0 0 0 0 785362711 0 0 0 1719788928 0 0 0 0 0 0 0 0 0 1531836478 1531836478 2...
result:
ok 500 lines
Test #6:
score: 0
Accepted
time: 4ms
memory: 107840kb
input:
200 500 5 27 388148671 5 119 680224137 173 87 986442294 66 147 118501544 22 147 676951375 161 5 727540296 93 5 232588510 147 88 385371846 196 147 314746005 35 178 19636528 98 5 242192853 195 178 544655136 55 5 271306482 5 155 942384947 56 178 303301289 181 5 671105997 147 153 54431483 5 142 49742903...
output:
0 0 0 194315768 0 0 201368555 0 0 194315768 0 0 194315768 0 194315768 0 0 0 395268412 0 0 194315768 3142868981 0 0 0 0 194315768 376961479 395268412 0 194315768 0 0 194315768 194315768 0 0 194315768 0 395268412 0 0 194315768 376961479 194315768 0 395268412 395268412 376961479 0 201368555 0 194315768...
result:
ok 500 lines
Test #7:
score: 0
Accepted
time: 1317ms
memory: 264800kb
input:
500000 500000 317156 54965 230759833 353491 77148 577942447 69059 132442 385326926 271915 94996 349962753 426805 265784 125714287 275095 49947 676489232 27293 430253 301562436 187863 475264 955971338 353263 433269 143567602 357681 310259 581877350 226404 39050 934609526 239119 204471 523754243 59587...
output:
1035108567 6886920194 393499496 9261470755 550314199 1035108567 1035108567 14330359099 550314199 393499496 0 1035108567 0 550314199 0 550314199 7341784214 393499496 550314199 550314199 393499496 550314199 550314199 0 1035108567 12626406441 14330359099 0 550314199 550314199 14330359099 1035108567 0 5...
result:
ok 500000 lines
Test #8:
score: 0
Accepted
time: 1295ms
memory: 263400kb
input:
500000 500000 101136 182341 255570946 45109 39454 824459295 292096 91801 196644175 300463 233417 961460180 5484 385014 198620547 464291 129845 942200533 99694 311784 122024892 27995 363914 559175166 200488 154575 773940047 92565 121726 574493648 180505 383816 397190682 231591 367594 936808806 4973 6...
output:
1720496473 0 16441040338 21036781141 0 14014394631 29189202442 8978191390 14014394631 29189202442 1720496473 14014394631 59812673829 7305842926 1720496473 1720496473 14014394631 10376295567 57941139695 25226868378 1720496473 14014394631 1720496473 7305842926 1720496473 8978191390 21036781141 3515557...
result:
ok 500000 lines
Test #9:
score: 0
Accepted
time: 1287ms
memory: 264900kb
input:
500000 500000 117422 56054 567560567 37609 51426 693318154 369948 25732 191341054 321431 469509 292868280 195218 150408 289330899 243114 32964 644463794 177181 3035 79162702 415066 204754 968798525 173772 440746 519973405 353210 75063 871376863 496610 208175 604393048 56122 126699 574969590 471302 3...
output:
19395057376 0 243758554869 0 19395057376 217129057419 0 86785348108 0 19395057376 0 0 406352878791 110510030058 326764779846 203656112567 28076461907 86785348108 301036711918 39759627385 0 0 86785348108 140469878703 86785348108 28076461907 28548372637 217129057419 19395057376 38312190750 21712905741...
result:
ok 500000 lines
Test #10:
score: 0
Accepted
time: 1310ms
memory: 265548kb
input:
500000 500000 385104 316086 203846482 90329 213814 14603218 119475 462619 752784726 498372 392323 865975281 304606 356710 129730417 242416 90188 373943907 292652 212607 63942753 111888 117722 855017284 362999 185574 323831658 302995 193341 143516276 370319 477011 115160893 212555 260622 552905885 40...
output:
961669517763 0 415448480082 125646612706 404921129645 0 378221674796 328765391722 262703284594 434520533651 415448480082 1168166453100 41888634064 114198363306 1064978063360 934717591514 729363217 221837076088 0 415448480082 305153161603 281434671538 2953480407378 630659988687 729363217 221837076088...
result:
ok 500000 lines
Test #11:
score: 0
Accepted
time: 1273ms
memory: 266512kb
input:
500000 500000 212178 335920 810458391 3968 383346 371060553 254524 168866 389037327 128669 470844 205547455 58828 217327 475404547 26846 200911 855903434 439798 233100 958501687 106285 324294 316767886 148013 368341 95627209 325855 279353 343917744 370568 273994 95266415 181067 395743 971354233 1930...
output:
1657697652188 588524410090 3986517524575 4292654087134 14745007507790 6859218245479 8699750506287 5877970905246 7621845358668 13425818817641 4291312458514 8886887696888 3970061425113 883771794077 2146471095474 6356949872854 9677944159886 601648300654 2818441761905 8473319373686 2772802043808 1320412...
result:
ok 500000 lines
Test #12:
score: 0
Accepted
time: 1153ms
memory: 264168kb
input:
500000 500000 31555 288134 394613692 355957 458485 375579843 126806 46407 545440829 406838 419632 549006915 172681 188725 236842242 105275 431054 900847846 478484 376936 229539493 433118 387062 650606705 23384 213517 58546600 254648 521 62347332 135409 21964 709872982 480882 107159 111319611 136690 ...
output:
248260194 248260194 248260194 765530529 765530529 0 248260194 248260194 0 0 248260194 1631260856 0 0 0 0 248260194 248260194 0 248260194 248260194 248260194 248260194 0 0 248260194 248260194 765530529 0 0 0 0 248260194 0 0 0 0 248260194 248260194 248260194 0 248260194 0 248260194 248260194 248260194...
result:
ok 500000 lines
Test #13:
score: 0
Accepted
time: 976ms
memory: 264928kb
input:
500000 500000 401547 432681 418666883 374165 94786 721328975 389649 185309 178564131 444634 139701 493003972 34811 377124 601980813 42045 398192 535069177 67009 437437 668672486 495940 197831 745314009 255457 10319 552592132 152468 134332 101366144 112209 341038 945768202 67542 275586 477864247 8089...
output:
0 854433336 0 0 0 0 1869108742 0 0 1517850672 0 0 0 0 854433336 854433336 1844438150 0 854433336 0 0 0 1517850672 0 0 0 0 0 0 0 1517850672 0 0 0 0 854433336 0 1517850672 0 0 0 0 0 0 0 0 0 0 0 1517850672 0 0 0 854433336 0 854433336 0 854433336 0 0 1517850672 0 0 1517850672 0 1517850672 1517850672 0 0...
result:
ok 500000 lines
Test #14:
score: 0
Accepted
time: 825ms
memory: 264436kb
input:
500000 500000 457852 271238 917738694 266814 474275 414331550 435124 77090 357330460 229795 188172 589247914 205253 173271 504388850 59713 483685 539037652 284974 376871 359402095 60301 499649 709358880 144507 224701 328191001 457309 40020 802196106 301404 356725 210765686 96399 290906 484238562 383...
output:
0 0 0 0 0 936571055 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 936571055 0 0 0 0 0 0 0 0 1511230822 0 0 0 0 936571055 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 3654148537 0 0 0 936571055 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 936571055 0 0 0 0 1986401741 0 0 0 0 0 0 0 0 0...
result:
ok 500000 lines
Test #15:
score: 0
Accepted
time: 633ms
memory: 262744kb
input:
500000 500000 43888 48212 179626807 450799 64537 503182622 271313 327157 748716512 89686 209891 668339242 244235 178213 13339384 387281 297281 487239241 362793 154117 821483132 225770 172442 336980690 5589 184727 928795315 310841 366390 410466687 131748 359089 752402192 61148 236886 35578549 490278 ...
output:
1371380934 0 0 0 0 0 0 0 0 0 0 0 1371380934 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 794586902 0 0 0 0 1371380934 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1968089286 0 1436483857 0 0 1831337801 0 0 0 1905534453 0 0 0 794586902 0 0 0 0 0 0 0 0 0 0 0 0 794586902 0 0 0 0 794586902 0 0 0 0 0 0 0 0 0 0 0 0 0 1642806249 0 0 0 ...
result:
ok 500000 lines
Extra Test:
score: 0
Extra Test Passed