QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#611730#9416. Intersection of PathstarjenAC ✓1781ms283620kbC++205.3kb2024-10-04 22:24:162024-10-04 22:24:17

Judging History

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

  • [2024-10-04 22:24:17]
  • 评测
  • 测评结果:AC
  • 用时:1781ms
  • 内存:283620kb
  • [2024-10-04 22:24:16]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=5e5+10;//注意开两倍大小的空间 在dp上
vector<pair<int,ll>>ve[maxn];
int dep[maxn];
pair<int,int>dp[21][maxn*2];
ll Dep[maxn];
int dfn[maxn],siz[maxn],lis[maxn],dfsid=0;
int L[maxn],R[maxn];
vector<int> sp;
void dfs(int x,int fa,ll l)
{
    dfsid++;
    L[x]=dfsid;
    lis[dfsid]=x;
    dep[x]=dep[fa]+1;
	Dep[x]=Dep[fa]+l;
    siz[x]=1;
    dfn[x] = sp.size();
    sp.push_back(x);
    for(auto [it,len]:ve[x])
	{
		if(it==fa) continue;
		dfs(it,x,len);
        sp.push_back(x);
        siz[x]+=siz[it];
    }
    R[x]=dfsid;
}
void initrmq()
{
    int n = sp.size();
    for (int i = 0; i < n; i++) dp[0][i] = {dfn[sp[i]], sp[i]};
    for (int i = 1; (1 << i) <= n; i++)
        for (int j = 0; j + (1 << i) - 1 < n; j++)
            dp[i][j] = min(dp[i - 1][j], dp[i - 1][j + (1 << (i - 1))]);
}
int lca(int u, int v)
{
    int l = dfn[u], r = dfn[v];
    if (l > r) swap(l, r);
    int k = __lg(r-l+1);
    return min(dp[k][l], dp[k][r - (1 << k) + 1]).second;
}
ll dis(int x,int y){
    int l=lca(x,y);
    return Dep[x]+Dep[y]-2*Dep[l];
}
struct info{
    int x,y;
    ll len;
    info(int _x=-1,int _y=-1){
        x=_x,y=_y;
        if(x==-1||y==-1)len=-1;
        else{
            len=dis(x,y);
        }
    }
    bool operator<(info a)const{
        return len<a.len;
    };
    bool operator>(info a)const{
        return len>a.len;
    };
    bool operator==(info a)const{
        return len==a.len;
    };
};
const info None =info(-1,-1);
info operator+(info x,info y){
    if(y.x==-1)return x;
    if(x.x==-1)return y;
    info mx=x;
    mx=max(mx,y);
    mx=max(mx,info(x.x,y.x));
    mx=max(mx,info(x.x,y.y));
    mx=max(mx,info(x.y,y.x));
    mx=max(mx,info(x.y,y.y));
    return mx;
};
struct Node{
    int l,r;
    info res;
    Node(){
        l=0,r=0;
        res=None;
    }
};
struct SegmentTree{
    Node a[maxn*4];
    void pushup(int i){
        if(a[i].l==a[i].r)return;
        a[i].res=a[i*2].res+a[i*2+1].res;
    }
    void build(int i,int l,int r){
        a[i].l=l,a[i].r=r;
        if(l==r){
            a[i].res=info(lis[a[i].l],lis[a[i].l]);
        }
        if(l>=r)return;
        int mid=(l+r)/2;
        build(i*2,l,mid);
        build(i*2+1,mid+1,r);
        pushup(i);
    }
    void update(int i,int x,info w){
        if(a[i].r<x||a[i].l>x)return;
        if(a[i].l>=x&&a[i].r<=x){
            a[i].res=w;
            return;
        }
        update(i*2,x,w);
        update(i*2+1,x,w);
        pushup(i);
    }
    info query(int i,int l,int r){
        if(a[i].r<l||a[i].l>r||l>r)return info(-1,-1);
        if(a[i].l>=l&&a[i].r<=r){
            return a[i].res;
        }
        return query(i*2,l,r)+query(i*2+1,l,r);
    }
};
SegmentTree tri;
struct Query{
    int a,b,k,id;
};
const bool test=false;
signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    int n,q;cin>>n>>q;
    vector<tuple<int,int,ll>> edges;
    for(int i=0;i<n-1;i++){
        int x,y,w;
        cin>>x>>y>>w;
        edges.emplace_back(x,y,w);
        ve[x].emplace_back(y,w);
        ve[y].emplace_back(x,w);
    }
    int root=1;
    {// get root
        vector<int> siz(n+1),fa(n+1);
        function<void(int,int)> dfs = [&](int x,int h){
            siz[x]=1;
            fa[x]=h;
            for(auto [it,len]:ve[x])if(it!=h){
                dfs(it,x);
                siz[x]+=siz[it];
            }
        };
        dfs(root,0);
        while(true){
            bool flag=false;
            for(auto [it,len]:ve[root])if(it!=fa[root]){
                if(siz[it]>n/2){
                    flag=true;
                    root=it;
                    break;
                }
            }
            if(!flag)break;
        }
    }
    dfs(root,0,0);
    if(test){
        cout<<"root="<<root<<endl;
        cout<<"lis :";for(int i=1;i<=n;i++)cout<<lis[i]<<" ";;cout<<endl;
    }
    for(auto &[x,y,w]:edges){
        if(dep[x]>dep[y])swap(x,y);
    }
    initrmq();
    tri.build(1,1,n);
    vector<int> intree(n);
    iota(intree.begin(),intree.end(),1);
    sort(intree.begin(),intree.end(),[&](int x,int y){
        return siz[x]>siz[y];
    });
    vector<Query> query(q);
    for(int i=0;i<q;i++)cin>>query[i].a>>query[i].b>>query[i].k,query[i].id=i;
    vector<ll> ans(q);
    sort(query.begin(),query.end(),[&](Query x,Query y){
        return x.k<y.k;
    });
    for(auto it:query){
        while(!intree.empty()&&siz[intree.back()]<it.k){
            tri.update(1,L[intree.back()],info(-1,-1));
            intree.pop_back();
        }
        auto [fa,son,len]=edges[it.a-1];
        info in=tri.query(1,L[son],R[son]);
        if(in.x==-1){
            ans[it.id]=tri.query(1,1,n).len;
            continue;
        }
        int delta=it.b-len;
        info out=tri.query(1,1,L[son]-1);
        if(R[son]<n)out=out+tri.query(1,R[son]+1,n);
        ll res=max(in.len,out.len);
        res=max(res,dis(in.x,out.x)+delta);
        res=max(res,dis(in.x,out.y)+delta);
        res=max(res,dis(in.y,out.x)+delta);
        res=max(res,dis(in.y,out.y)+delta);
        ans[it.id]=res;
    }
    for(int i=0;i<q;i++)cout<<ans[i]<<"\n";
}

这程序好像有点Bug,我给组数据试试?

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 4ms
memory: 62820kb

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: 9ms
memory: 59868kb

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: 0ms
memory: 59140kb

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: 4ms
memory: 50584kb

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: 4ms
memory: 50872kb

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: 7ms
memory: 66608kb

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: 1781ms
memory: 279368kb

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: 1651ms
memory: 279580kb

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: 1626ms
memory: 279680kb

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: 1638ms
memory: 280100kb

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: 1608ms
memory: 283620kb

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: 1467ms
memory: 281528kb

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: 1419ms
memory: 279772kb

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: 1368ms
memory: 278904kb

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: 1354ms
memory: 279096kb

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