QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#354324 | #4050. 填树 | Physics212303 | 100 ✓ | 1799ms | 3844kb | C++17 | 2.0kb | 2024-03-15 09:00:43 | 2024-03-15 09:00:44 |
Judging History
answer
#include<bits/stdc++.h>
#define int long long
using namespace std;
typedef pair<int,int> pii;
const int p=1e9+7;
int qpow(int a,int b){
int r=1;
while(b){
if(b&1)(r*=a)%=p;
(a*=a)%=p,b>>=1;
}
return r;
}
int lagrange(vector<pii> &a,int k){
int c=0;
for(int i=0;i<a.size();i++){
int s1=a[i].second%p,s2=1;
for(int j=0;j<a.size();j++)
if(i!=j)s1=s1*(k-a[j].first)%p,
s2=s2*(a[i].first-a[j].first)%p;
(c+=s1*qpow((s2%p+p)%p,p-2)%p+p)%=p;
}
return c;
}
main(){
ios::sync_with_stdio(false);
int n,K,m=0,c1=0,c2=0; cin>>n>>K;
vector<int> a={1};
vector<pii> b(n);
for(auto &[l,r]:b){
cin>>l>>r,m=max(m,r+1);
a.emplace_back(l);
a.emplace_back(r);
if(l>K)a.emplace_back(l-K);
if(r>K)a.emplace_back(r-K);
}
a.emplace_back(m);
sort(a.begin(),a.end());
m=unique(a.begin(),a.end())-a.begin();
vector<vector<int> > g(n);
for(int i=1;i<n;i++){
int u,v; cin>>u>>v;
g[--u].emplace_back(--v);
g[v].emplace_back(u);
}
vector<int> f1(n),f2(n),s1(n),s2(n);
function<void(int,int,int,int)> dfs=[&](int u,int f,int l,int r){
int rl=max(l,b[u].first),rr=min(r,b[u].second);
int c1=(rl<=rr?rr-rl+1:0),c2=(rl<=rr?((rl+rr)*(rr-rl+1)>>1)%p:0);
f1[u]=s1[u]=c1,f2[u]=s2[u]=c2;
for(int i:g[u])
if(i!=f){
dfs(i,u,l,r),(f1[u]+=f1[i])%=p,(f2[u]+=f2[i])%=p;
(f2[u]+=s1[u]*s2[i]+s1[i]*s2[u])%=p,(s2[u]+=s1[i]*c2+s2[i]*c1)%=p;
(f1[u]+=s1[u]*s1[i])%=p,(s1[u]+=s1[i]*c1)%=p;
}
};
for(int i=0;i<m-1;i++){
int l=a[i],r=a[i]+K,d=0;
vector<pii> p1,p2;
while(d<n+2){
if(a[i]+d==a[i+1])break;
dfs(0,0,l,r),(c1+=f1[0])%=p,(c2+=f2[0])%=p;
dfs(0,0,++l,r),(c1+=p-f1[0])%=p,(c2+=p-f2[0])%=p;
p1.emplace_back(a[i]+d,c1);
p2.emplace_back(a[i]+d,c2);
d++,r++;
}
if(a[i]+d<a[i+1])
c1=lagrange(p1,a[i+1]-1),c2=lagrange(p2,a[i+1]-1);
}
cout<<c1<<endl<<c2<<endl;
return 0;
}
詳細信息
Test #1:
score: 10
Accepted
time: 1ms
memory: 3548kb
input:
5 1 3 6 5 6 1 8 1 4 3 6 2 1 3 2 4 1 5 2
output:
89 1035
result:
points 1.0 Right Answer!
Test #2:
score: 10
Accepted
time: 6ms
memory: 3844kb
input:
30 137096004 215692601 593148870 587744254 908728660 354367633 568826817 376073684 818829717 535492238 780479755 232775004 650109673 251965857 701073037 143963540 496974493 55915221 744763438 528234065 732528154 332418107 641577253 13159384 780093251 179253217 905083657 430741053 697503733 87499240 ...
output:
354648863 631656809
result:
points 1.0 Right Answer!
Test #3:
score: 10
Accepted
time: 6ms
memory: 3828kb
input:
30 250086104 591069936 968891212 41581360 609904362 262819200 944260403 535918368 583285015 263875027 793847733 138437402 676792228 597402197 736836166 438565277 486906152 342827909 610036059 328767032 512083092 437385632 703793342 523490836 570259000 325460973 781713097 202545410 819125374 49381546...
output:
712687176 206651743
result:
points 1.0 Right Answer!
Test #4:
score: 10
Accepted
time: 1ms
memory: 3840kb
input:
30 143 177 217 32 208 209 318 152 463 187 385 160 475 43 346 163 273 2 426 219 267 191 455 210 246 102 483 130 257 194 378 256 370 279 347 220 351 56 333 192 387 167 254 85 211 292 437 180 492 111 390 285 478 297 428 43 414 182 296 126 374 2 1 3 2 4 2 5 2 6 4 7 1 8 3 9 2 10 6 11 7 12 6 13 3 14 8 15 ...
output:
362561768 493898850
result:
points 1.0 Right Answer!
Test #5:
score: 10
Accepted
time: 871ms
memory: 3604kb
input:
200 67630 117218 161430 70358 166290 26412 193532 66149 121289 92339 117825 64209 152682 48781 183530 86224 186305 51599 143557 46140 191874 42871 88142 50177 123036 43200 105591 19016 97454 70014 147624 6141 197253 85275 198926 115374 134032 52355 119685 12417 193878 6361 169371 86153 180522 61286 ...
output:
158279748 290430672
result:
points 1.0 Right Answer!
Test #6:
score: 10
Accepted
time: 954ms
memory: 3832kb
input:
200 19198 21280 117277 90662 123986 45289 179202 63408 136645 46256 98728 117947 166570 55778 175190 89589 103669 119147 182875 5585 91771 68300 145843 70733 109963 61418 157603 63596 164653 81734 110752 109084 137376 95705 166924 589 133255 73046 114963 87681 194475 74593 179939 102071 116794 28707...
output:
584166745 705498146
result:
points 1.0 Right Answer!
Test #7:
score: 10
Accepted
time: 1630ms
memory: 3680kb
input:
200 216054723 443948382 766438713 468188882 870457165 68166269 745871349 537369301 978917205 328904568 676155793 511075340 824468057 93969870 635291060 303629013 656508336 420101343 832868347 259545478 517757019 593962769 912428239 256177328 983461740 115320903 852333642 279416317 719120507 47587791...
output:
93827485 825656833
result:
points 1.0 Right Answer!
Test #8:
score: 10
Accepted
time: 1799ms
memory: 3620kb
input:
200 69033242 285053641 976355712 227553452 938314736 107179948 750434085 303626071 690497167 439733858 799894196 113776149 659462530 121522752 575933362 418433076 542866700 567079971 780647210 183890864 824783214 380023995 846912184 71118369 969692168 262487491 849298427 90348662 619018202 251961261...
output:
712593509 913113589
result:
points 1.0 Right Answer!
Test #9:
score: 10
Accepted
time: 1445ms
memory: 3616kb
input:
200 238518392 537484342 867288829 375663129 568281320 68193346 485121003 404605326 952659797 101768795 715315465 233224149 568371067 144921013 840998588 181380439 865915297 197203040 508386871 557417302 592025048 12752815 704019284 72698900 677587957 370489735 950055609 583359215 939650067 359418111...
output:
166999279 732641046
result:
points 1.0 Right Answer!
Test #10:
score: 10
Accepted
time: 1451ms
memory: 3668kb
input:
200 239255629 523317820 588402780 280886988 468771488 496202333 677770342 572534106 822314012 398157554 674960423 590860104 791274038 547846359 984625596 348890270 852572492 79439545 521421058 338618714 733050443 520589139 848284325 226194319 568526848 536193964 654742253 86493140 959602843 53836008...
output:
560344075 299371604
result:
points 1.0 Right Answer!
Extra Test:
score: 0
Extra Test Passed