QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#832531#5350. 网络hhoppitree100 ✓309ms19544kbC++173.2kb2024-12-25 22:32:572024-12-25 22:32:57

Judging History

你现在查看的是最新测评结果

  • [2024-12-25 22:32:57]
  • 评测
  • 测评结果:100
  • 用时:309ms
  • 内存:19544kb
  • [2024-12-25 22:32:57]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;

const int N = 1e5 + 5;

vector< pair<int, int> > G[N];
long long dis[N];

void dfs(int x, int fa = -1) {
    for (auto [v, w] : G[x]) {
        if (v != fa) dis[v] = dis[x] + w, dfs(v, x);
    }
}

int hv[N], id[N];

void Dfs(int x, int fa = -1) {
    for (auto [v, w] : G[x]) {
        if (v != fa) Dfs(v, x), hv[x] |= hv[v];
    }
}

void getChain(int x, int fa = -1) {
    if (hv[x]) id[x] = ++id[0];
    for (auto [v, w] : G[x]) if (v != fa) getChain(v, x);
}

long long len[N], mx[N];

void get(int x, int fa = -1, long long D = 0, int wh = 0) {
    if (id[x]) len[id[x]] = D;
    else mx[wh] = max(mx[wh], D);
    for (auto [v, w] : G[x]) {
        if (v == fa) continue;
        if (hv[x] && !hv[v]) get(v, x, w, id[x]);
        else get(v, x, D + w, wh);
    }
}

vector< pair<long long, int> > ord1, ord2;

int check(int n, long long L, long long d) {
    long long mx1 = -1e18, mx2 = -1e18, A = -1e18, B = -1e18, C = -1e18, D = -1e18;
    for (int i = 0, j = n - 1; i < n; ++i) {
        while (~j && ord1[i].first + ord2[j].first > d) {
            mx1 = max(mx1, mx[ord2[j].second] + len[ord2[j].second]);
            mx2 = max(mx2, mx[ord2[j].second] - len[ord2[j].second]);
            --j;
        }
        A = max(A, mx[ord1[i].second] + len[ord1[i].second] + mx1);
        B = max(B, mx[ord1[i].second] - len[ord1[i].second] + mx1);
        C = max(C, mx[ord1[i].second] + len[ord1[i].second] + mx2);
        D = max(D, mx[ord1[i].second] - len[ord1[i].second] + mx2);
    }
    A += L - d, B += L - d, C += L - d, D += L - d;
    for (int i = 1, p = n + 1, q = 1, r = 0, s = n; i <= n; ++i) {
        while (p >= 2 && len[i] + len[p - 1] >= A) --p;
        while (q <= n && -len[i] + len[q] < B) ++q;
        while (r <= n - 1 && len[i] - len[r + 1] >= C) ++r;
        while (s >= 1 && -len[i] - len[s] < D) --s;
        if (max(p, q) <= min(r, s)) return 1;
    }
    return 0;
}

signed main() {
    int n, L;
    while (~scanf("%d%d", &n, &L) && n && L) {
        for (int i = 1; i <= n; ++i) G[i].clear();
        for (int i = 1, x, y, l; i < n; ++i) {
            scanf("%d%d%d", &x, &y, &l);
            G[x].push_back({y, l});
            G[y].push_back({x, l});
        }
        dis[1] = 0, dfs(1);
        int x = max_element(dis + 1, dis + n + 1) - dis;
        dis[x] = 0, dfs(x);
        int y = max_element(dis + 1, dis + n + 1) - dis;
        id[0] = 0;
        for (int i = 1; i <= n; ++i) hv[i] = (i == y), id[i] = 0;
        Dfs(x), getChain(x);
        for (int i = 1; i <= n; ++i) len[i] = mx[i] = 0;
        get(x);
        ord1.clear(), ord2.clear();
        for (int i = 1; i <= id[0]; ++i) {
            ord1.push_back({mx[i] + len[i], i});
            ord2.push_back({mx[i] - len[i], i});
        }
        sort(ord1.begin(), ord1.end()), sort(ord2.begin(), ord2.end());
        long long l = 0, r = dis[y], res = r + 1;
        while (l <= r) {
            long long mid = (l + r) >> 1;
            if (check(id[0], L, mid)) res = mid, r = mid - 1;
            else l = mid + 1;
        }
        printf("%lld\n", res);
    }
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Pretests


Final Tests

Test #1:

score: 5
Accepted
time: 0ms
memory: 7800kb

input:

10 957
1 2 283
2 6 2004
4 2 3077
9 1 2095
7 2 1053
2 8 861
9 10 2604
8 5 991
3 1 563
10 1316
9 8 2033
4 8 1885
4 7 124
10 7 1672
10 3 2205
4 2 1974
10 1 3216
5 9 39
8 6 3032
3 2147483647
1 2 2147483647
3 2 2147483647
5 2147483647
2 1 2147483647
3 2 2147483647
5 3 2147483647
4 5 2147483647
10 335
5 9...

output:

5455
7564
2147483647
4294967294
6277

result:

ok 5 number(s): "5455 7564 2147483647 4294967294 6277"

Test #2:

score: 5
Accepted
time: 2ms
memory: 8744kb

input:

20 443
3 4 778
4 9 594
4 7 587
19 3 250
4 15 363
17 4 291
19 14 564
6 17 541
3 1 773
17 8 12
6 13 568
10 1 183
15 2 63
18 2 68
8 5 330
20 8 823
3 12 270
16 7 194
11 5 212
20 118
4 8 951
8 6 1088
6 14 409
3 14 877
3 16 1179
16 15 189
5 15 385
5 11 604
10 11 252
3 19 800
6 18 661
13 15 169
2 10 413
15...

output:

2508
4162
6131
2147483647
4294967294
15028
4286
5607
5227
2126
1542

result:

ok 11 numbers

Test #3:

score: 5
Accepted
time: 0ms
memory: 9012kb

input:

46 31
39 4 378
39 20 404
4 11 461
2 39 62
20 45 398
11 3 225
4 34 406
33 39 502
41 4 528
4 27 442
35 45 458
35 25 535
14 11 380
31 3 106
29 11 213
20 9 77
18 29 151
3 7 50
21 3 182
18 37 299
45 40 271
15 9 419
7 12 71
16 7 52
4 17 326
35 32 101
13 3 292
38 31 362
40 30 203
23 45 320
24 35 443
17 10 ...

output:

2520
3987
5827
2147483647
4294967294
15326
10733
12138
3542

result:

ok 9 numbers

Test #4:

score: 5
Accepted
time: 2ms
memory: 7684kb

input:

47 989
34 38 904
34 31 1117
23 38 664
24 34 1340
24 44 863
24 28 292
31 41 491
38 27 892
38 39 314
44 6 2042
3 41 785
28 15 1850
39 21 1401
36 44 191
45 21 53
33 36 152
44 26 603
18 21 125
46 28 422
17 27 1016
47 31 1694
38 42 137
29 28 838
40 33 186
41 8 1446
10 44 1580
43 15 1140
35 39 1285
15 30 ...

output:

9086
14925
21423
2147483647
4294967294
60817
37185
41307
20004

result:

ok 9 numbers

Test #5:

score: 5
Accepted
time: 2ms
memory: 8608kb

input:

64 61
3 61 1001
3 60 1913
58 61 407
58 28 1799
3 54 1850
3 48 1259
61 49 656
19 48 675
49 31 1952
42 31 453
49 29 1128
39 58 1932
33 49 132
18 19 931
35 42 59
33 53 262
32 19 1070
25 58 1659
55 39 1123
12 60 998
12 37 286
29 26 258
34 55 448
42 62 328
41 25 34
16 58 1074
42 13 703
45 12 1361
22 61 1...

output:

10383
19451
26336
2147483647
4294967294
84811
75176
80233
22260

result:

ok 9 numbers

Test #6:

score: 5
Accepted
time: 0ms
memory: 7516kb

input:

296 298
39 46 1755
39 232 989
8 46 1265
83 46 306
234 46 675
133 232 1381
133 15 1499
83 120 1725
8 55 181
133 56 15
38 120 912
55 76 1348
252 46 272
205 15 1525
15 13 2131
13 198 1805
78 15 1640
46 91 1165
78 14 435
234 20 1878
75 205 1518
37 75 1780
47 133 1806
15 86 482
92 13 334
155 75 831
158 1...

output:

25406
158668
302577
2147483647
4294967294
418549
150936
156441
121166

result:

ok 9 numbers

Test #7:

score: 5
Accepted
time: 3ms
memory: 7704kb

input:

292 2190
228 235 4313
228 167 3309
167 126 887
175 126 203
236 126 336
52 228 4006
112 236 2243
235 216 1
292 126 4024
7 175 2752
74 126 941
100 52 4590
168 175 3421
84 52 2358
235 63 2456
167 211 1113
33 52 2917
72 33 1957
43 292 1417
117 43 2286
235 224 3035
52 125 3598
216 54 2860
125 173 3370
12...

output:

47309
344526
639998
2147483647
4294967294
986345
339357
329065
260708

result:

ok 9 numbers

Test #8:

score: 5
Accepted
time: 3ms
memory: 9476kb

input:

298 234
41 279 60
279 134 366
41 5 2491
279 8 2257
46 5 436
95 279 548
92 95 2474
52 41 2099
202 134 2675
121 95 697
76 46 957
13 52 1742
162 279 1602
8 7 194
11 46 1870
278 95 1651
31 162 1255
46 291 932
211 278 1778
52 189 794
211 220 2526
189 112 2571
7 242 2293
162 27 1226
112 47 2142
90 31 1643...

output:

25640
198722
383271
2147483647
4294967294
555715
175018
181077
142226

result:

ok 9 numbers

Test #9:

score: 5
Accepted
time: 2ms
memory: 8116kb

input:

997 141
819 482 1942
676 482 1633
482 11 1221
482 797 1941
11 325 192
11 370 1225
104 11 274
370 674 407
276 104 572
104 701 98
16 674 819
701 975 1507
468 975 814
482 594 1851
550 11 1731
706 819 37
16 766 1305
550 285 537
885 468 420
150 701 732
940 285 1552
824 104 660
11 395 115
797 403 782
674 ...

output:

27260
440534
196882
460683
511547
385107
1348002
943002
2147483647
4294967294
174090

result:

ok 11 numbers

Test #10:

score: 5
Accepted
time: 5ms
memory: 7836kb

input:

916 699
780 814 2734
814 222 2579
222 534 1357
222 343 139
272 222 3145
814 835 2239
814 862 1290
178 862 1918
780 639 879
639 704 3670
464 178 2892
639 564 1340
850 464 997
464 50 374
547 343 1889
627 780 1664
343 784 2616
496 627 1483
704 140 3761
343 901 616
784 635 1532
140 805 3335
343 667 1761...

output:

50656
937413
454122
910173
935843
761356
2706426
1760678
2147483647
4294967294
370190

result:

ok 11 numbers

Test #11:

score: 5
Accepted
time: 41ms
memory: 10476kb

input:

4796 727
2703 453 2739
2703 3049 179
1421 3049 3536
2829 1421 3568
3049 2145 1004
2145 4277 1669
2145 1210 885
2145 4607 4441
2580 1210 1772
4607 3940 729
4726 4607 396
2703 1539 3043
143 3940 3993
1054 1210 489
4277 4475 538
1210 2359 3328
4311 1210 1321
2580 1071 2866
4475 319 250
1539 2983 864
29...

output:

73199
2830062
11243287
11686429
16705190
48874709
66731031
4591288
13535854
21256486
2147483647
4294967294
3808654

result:

ok 13 numbers

Test #12:

score: 5
Accepted
time: 41ms
memory: 10296kb

input:

4924 633
4077 1081 2223
2955 1081 3134
1081 4491 2147
129 1081 3670
4491 3889 2581
4237 4077 764
3140 129 917
2130 1081 2642
2955 2046 439
1623 2130 99
3140 4800 2683
3411 1081 1186
1638 4491 3723
2130 3066 857
558 1638 917
3681 4237 1610
3240 3889 2128
3007 2046 194
844 3411 1147
3703 4077 2714
314...

output:

59512
2297677
8382880
8719409
12701086
36814673
52481104
3732801
10077363
17120650
2147483647
4294967294
3012800

result:

ok 13 numbers

Test #13:

score: 5
Accepted
time: 43ms
memory: 11116kb

input:

4761 192
2352 375 1860
2352 4696 3503
2352 2556 630
1805 375 1085
1805 4129 233
4438 2556 2195
3015 1805 590
2352 4192 2124
375 3203 966
2352 1770 443
3133 375 3916
1770 2239 295
1944 3133 315
1784 4192 3661
4696 656 3397
2646 1770 3117
2556 4561 68
1944 5 2144
4083 2352 489
3015 242 2694
2352 380 1...

output:

63055
2442107
9294364
9748708
13410080
41648538
62640217
4150997
10658389
18092325
2147483647
4294967294
3116522

result:

ok 13 numbers

Test #14:

score: 5
Accepted
time: 37ms
memory: 10692kb

input:

4891 244
4685 1980 837
4685 2685 1040
4205 4685 142
4205 213 2134
3002 4685 1423
4685 2901 1006
2685 1946 452
3835 4205 249
1299 213 2096
162 213 1728
162 2564 793
4422 2685 997
4205 519 220
1980 694 27
213 2160 1552
1296 3002 1255
2042 4685 468
2044 1299 1561
3438 2044 354
1452 1980 1273
241 2564 2...

output:

34858
1384101
5002102
5343806
7832834
21777220
31344055
2190794
6380986
9989897
2147483647
4294967294
1728690

result:

ok 13 numbers

Test #15:

score: 5
Accepted
time: 35ms
memory: 10180kb

input:

4684 271
2218 461 127
3630 461 674
4112 3630 108
417 461 370
2218 1125 904
511 417 466
2218 2265 297
2218 3669 372
2751 1125 206
2218 1024 81
4112 495 310
234 511 686
1211 4112 926
2256 3630 189
676 4112 28
511 301 254
1255 3669 123
1125 3522 544
1021 2265 402
1447 676 637
2509 495 130
1367 1024 931...

output:

17615
576697
2226092
2368069
3433173
9606560
11942606
943129
2656813
4485732
2147483647
4294967294
773696

result:

ok 13 numbers

Test #16:

score: 5
Accepted
time: 299ms
memory: 19156kb

input:

24094 66
19002 16021 1388
16021 380 1761
16046 19002 1147
22179 19002 416
16046 18342 1326
22179 6326 466
19345 16046 615
16021 19829 1249
17238 19345 998
15773 16046 1630
22442 19345 604
17238 21999 1037
11402 380 1613
15680 22442 1681
16046 16204 1258
1802 11402 1095
15805 18342 1121
1826 22179 75...

output:

39175
5610717
20691800
21387986
30806161
81185521
123441098
8716517
26420646
40673076
2147483647
4294967294
7018348

result:

ok 13 numbers

Test #17:

score: 5
Accepted
time: 309ms
memory: 19488kb

input:

23445 1433
22490 20906 1770
20906 10975 2814
10975 10804 1624
10804 4189 936
9788 10804 1291
9147 9788 2787
10804 10954 3022
3549 10975 2384
22490 11142 2358
10804 2903 2293
4189 8702 21
21108 10975 2639
5831 10804 2555
10975 15894 972
15984 20906 1385
14506 20906 1956
20906 18811 3015
14506 11494 2...

output:

61282
8805603
37308662
39416784
56733902
142006777
207958438
14793184
44778554
71852863
2147483647
4294967294
12001104

result:

ok 13 numbers

Test #18:

score: 5
Accepted
time: 285ms
memory: 19544kb

input:

23266 505
11641 10002 272
10002 10187 1280
15897 10187 1626
13154 15897 3626
15707 10187 2258
15897 1592 2556
1592 22558 3135
10187 6374 1241
15897 17267 3427
15897 11393 3907
17037 11393 3926
7278 6374 3236
15897 7065 2401
20643 11393 3624
17457 6374 1061
2804 10002 3601
21347 10002 3285
17457 2142...

output:

88039
13019611
54238964
58118400
81343650
198322128
288622653
21132515
61126030
100378426
2147483647
4294967294
17219358

result:

ok 13 numbers

Test #19:

score: 5
Accepted
time: 290ms
memory: 19508kb

input:

23599 625
6632 5508 848
6632 370 1445
20170 5508 760
5508 4912 21
370 18332 179
6632 4250 891
18332 10748 491
19472 10748 1115
5508 19939 1086
20170 13556 1381
20615 6632 1356
12385 10748 1369
4250 5106 140
1717 20615 1087
6421 13556 1349
18332 14692 608
8147 10748 533
6421 1713 243
4168 6632 1548
1...

output:

34404
4875956
17902894
18709656
26485191
78689697
113840150
7526492
21774129
35020170
2147483647
4294967294
5834776

result:

ok 13 numbers

Test #20:

score: 5
Accepted
time: 273ms
memory: 19392kb

input:

23950 205
19087 14505 397
14505 4532 158
14505 7591 212
19586 19087 377
16628 19586 42
19586 6246 160
4002 19087 230
16412 19087 69
19087 6489 206
18009 16412 58
20523 4002 330
16044 6246 5
7591 12316 35
16044 12993 418
14869 6246 184
20523 7026 331
20200 20523 324
12993 17425 107
20200 6663 248
205...

output:

8953
1348866
5580190
6019755
7828614
23772015
33886214
2318949
6126632
9855169
2147483647
4294967294
1736386

result:

ok 13 numbers

Extra Test:

score: 0
Extra Test Passed