QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#864479 | #6969. 幻想乡战略游戏 | msk_sama | 0 | 182ms | 27016kb | C++20 | 3.1kb | 2025-01-20 17:18:37 | 2025-01-20 17:18:46 |
Judging History
answer
#include <set>
#include <map>
#include <queue>
#include <ctime>
#include <cstdio>
#include <vector>
#include <cassert>
#include <cstring>
#include <algorithm>
#define fi first
#define se second
#define ep emplace
#define MISAKA main
#define ll long long
#define eb emplace_back
#define pii pair<int,int>
#define rg(x) x.begin(),x.end()
#define pc(x) __builtin_popcount(x)
#define mems(a,x) memset(a,x,sizeof(a))
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define _rep(i,a,b) for(int i=(a);i>=(b);--i)
#define debug(...) fprintf(stderr,__VA_ARGS__)
#define FIO(FILE) freopen(FILE".in","r",stdin),freopen(FILE".out","w",stdout)
using namespace std;
bool __st;
inline int read(){
char c=getchar();int f=1,x=0;
for(;c<48||c>57;c=getchar())if(c=='-') f=-1;
for(;47<c&&c<58;c=getchar()) x=(x<<3)+(x<<1)+(c^48);
return x*f;
}
const int N=1e5+10,mod=998244353;
int n,q,rt,fa[N],vis[N],son[N],sz[N],top[N],dfn[N],tim;ll d[N],a[N],s1,s2;
vector<pii> g[N];vector<int> G[N];
void dfs1(int u,int f){
fa[u]=f,sz[u]=1;
for(auto [v,w]:g[u])if(v!=f){
d[v]=d[u]+w,dfs1(v,u),sz[u]+=sz[v];
if(sz[v]>sz[son[u]]) son[u]=v;
}
}
void dfs2(int u,int tp){
dfn[u]=++tim,top[u]=tp;if(son[u]) dfs2(son[u],tp);
for(auto [v,w]:g[u])if(v!=fa[u]&&v!=son[u]) dfs2(v,v);
}
#define go(u) for(auto [v,w]:g[u])if(v!=f&&!vis[v])
void getsz(int u,int f){sz[u]=1;go(u)getsz(v,u),sz[u]+=sz[v];}
void find(int u,int f,int n){
int mx=n-sz[u];
go(u) find(v,u,n),mx=max(mx,sz[v]);
if(mx<=n/2) rt=u;
}
int bd(int u){
getsz(u,0);find(u,0,sz[u]);int f=-1;
vis[u=rt]=1;go(u) G[u].eb(bd(v));return u;
}
struct bit{
ll c[N];bit(){mems(c,0);}
void upd(int x,ll k){for(;x<=n;x+=x&-x)c[x]+=k;}
ll qry(int x){ll r=0;for(;x;x^=x&-x)r+=c[x];return r;}
ll qry(int l,int r){return l<=r?qry(r)-qry(l-1):0;}
}t1,t2;
void upd(int u,ll k){
t1.upd(dfn[u],k);s1+=k,s2+=k*d[u];int x=u;
for(;u;u=fa[top[u]]) t2.upd(dfn[u],k*d[x]),a[u]+=k*d[x];
}
ll qry(int u){
ll s=d[u]*t1.qry(dfn[u],dfn[u]+sz[u]-1);int _=u;
for(;u;u=fa[top[u]]){
s+=t2.qry(dfn[top[u]],dfn[u]-1);
int x=top[u],y=fa[x],z=son[y];
if(!y) break;
s+=a[y]+d[y]*(-t1.qry(dfn[x],dfn[x]+sz[x]-1)+t1.qry(dfn[z],dfn[z]+sz[z]-1));
}
return s1*d[_]+s2-2ll*s;
}
ll solve(int u,ll x){
if(G[u].empty()) return x;
int id=-1;ll p=x;
for(int v:G[u]){
ll t=qry(v);
if(t<p) id=v,p=t;
}
return id==-1?x:solve(id,p);
}
void misaka(){
n=read(),q=read();
rep(i,2,n){
int u=read(),v=read(),w=read();
g[u].eb(v,w);g[v].eb(u,w);
}
rt=bd(1);dfs1(1,0);dfs2(1,1);
while(q--){
int u=read(),k=read();
upd(u,k);
printf("%lld\n",solve(rt,qry(rt)));
}
}
bool __ed;
signed MISAKA(){
#ifdef LOCAL_MSK
atexit([](){
debug("\n%.3lfs ",(double)clock()/CLOCKS_PER_SEC);
debug("%.3lfMB\n",abs(&__st-&__ed)/1024./1024);});
#endif
int T=1;
while(T--) misaka();
return 0;
}
詳細信息
Pretests
Final Tests
Test #1:
score: 0
Wrong Answer
time: 2ms
memory: 10996kb
input:
5000 2000 1 2 701 2 3 811 3 4 548 4 5 703 5 6 32 6 7 435 7 8 368 8 9 978 9 10 68 10 11 550 11 12 667 12 13 270 13 14 486 14 15 217 15 16 486 16 17 326 17 18 418 18 19 361 19 20 344 20 21 116 21 22 373 22 23 38 23 24 563 24 25 591 25 26 800 26 27 94 27 28 210 28 29 548 29 30 278 30 31 169 31 32 1000 ...
output:
-22032 7430217 12699897 84148972 85037820 733116681 739126719 837206280 1065126461 1272631525 1493516149 1715235118 1787613108 1959232181 2345294055 2445830827 2602500963 2573077400 2844519827 2872342347 2880230463 3005438847 3012381327 3188288565 3260393767 3354314848 3680278792 3862028562 39402495...
result:
wrong answer 1st numbers differ - expected: '0', found: '-22032'
Test #2:
score: 0
Wrong Answer
time: 2ms
memory: 9980kb
input:
5000 2000 1 2 576 2 3 745 3 4 672 4 5 812 5 6 770 6 7 261 7 8 191 8 9 534 9 10 209 10 11 576 11 12 184 12 13 212 13 14 996 14 15 466 15 16 360 16 17 127 17 18 180 18 19 804 19 20 74 20 21 504 21 22 912 22 23 253 23 24 113 24 25 418 25 26 723 26 27 596 27 28 92 28 29 845 29 30 215 30 31 96 31 32 224 ...
output:
47574145 97887793 186799462 189079894 292423850 320590058 600753046 604042821 976676081 1045525791 1115445245 1407201683 1432668425 1441808099 1442749967 1735448381 1739305091 2064543443 2158006589 2166538972 2166796201 2303592361 2314347497 2344254857 2380758207 2496439977 2754105513 2820338421 294...
result:
wrong answer 1st numbers differ - expected: '0', found: '47574145'
Test #3:
score: 0
Wrong Answer
time: 2ms
memory: 8220kb
input:
5000 2000 1 2 149 2 3 122 3 4 778 4 5 764 5 6 514 6 7 905 7 8 289 8 9 151 9 10 976 10 11 315 11 12 429 12 13 517 13 14 488 14 15 679 15 16 354 16 17 597 17 18 583 18 19 378 19 20 128 20 21 990 21 22 123 22 23 893 23 24 859 24 25 140 25 26 188 26 27 142 27 28 620 28 29 735 29 30 662 30 31 261 31 32 9...
output:
-9072 6791367 35417612 435829236 455989311 674976303 675066458 717123568 879753068 880513784 1025678981 1102920009 1112533818 1140491748 1636358726 1661743939 1978150004 2082258170 2086965158 2184980690 2189219474 2263262744 2450753768 2583457850 2588682714 2609321593 2681362765 2760904885 278839342...
result:
wrong answer 1st numbers differ - expected: '0', found: '-9072'
Test #4:
score: 0
Wrong Answer
time: 70ms
memory: 27000kb
input:
100000 100000 1 2 31 2 3 400 3 4 488 4 5 524 5 6 665 6 7 63 7 8 381 8 9 375 9 10 936 10 11 157 11 12 657 12 13 346 13 14 408 14 15 288 15 16 138 16 17 785 17 18 15 18 19 109 19 20 319 20 21 659 21 22 773 22 23 703 23 24 995 24 25 974 25 26 159 26 27 163 27 28 468 28 29 915 29 30 245 30 31 634 31 32 ...
output:
2578560 6537843850 22263441753 26281474205 35948586725 41376387695 53413640855 70041831459 72888863907 74091590354 77913715139 93395124361 100693273031 101897488303 103840745101 105202379326 113299573740 124627913378 126456708254 129151682927 130365244453 140132527380 143772468231 148605639756 16200...
result:
wrong answer 1st numbers differ - expected: '0', found: '2578560'
Test #5:
score: 0
Wrong Answer
time: 70ms
memory: 27016kb
input:
100000 100000 1 2 460 2 3 195 3 4 548 4 5 573 5 6 835 6 7 147 7 8 107 8 9 619 9 10 881 10 11 982 11 12 185 12 13 152 13 14 98 14 15 153 15 16 14 16 17 925 17 18 651 18 19 226 19 20 175 20 21 968 21 22 25 22 23 695 23 24 597 24 25 353 25 26 803 26 27 958 27 28 598 28 29 535 29 30 330 30 31 743 31 32 ...
output:
32025684 6869202150 8590033189 20942263067 41894090407 45275929878 49497514086 52877742168 57814378452 61555908042 78327457164 93840847028 99828446390 99934842020 101013101249 109345169084 117876864105 134615753506 140163060898 142867046570 148940871974 157062564004 161088296740 169713953977 1703137...
result:
wrong answer 1st numbers differ - expected: '0', found: '32025684'
Test #6:
score: 0
Wrong Answer
time: 182ms
memory: 18972kb
input:
100000 100000 1 2 121 2 3 761 1 4 427 1 5 833 1 6 28 6 7 336 5 8 977 8 9 347 1 10 124 3 11 13 10 12 525 4 13 407 7 14 546 3 15 279 2 16 707 11 17 835 13 18 300 17 19 138 6 20 763 3 21 607 17 22 118 22 23 192 7 24 865 21 25 86 23 26 98 10 27 691 25 28 643 20 29 285 10 30 526 24 31 194 8 32 227 31 33 ...
output:
-614510 -6955344 -3035505 -3748124 -20448592 -15835588 -17656258 -22435106 -24508082 -29099474 -40851005 -42681925 -39407354 -42133752 -42636086 -36454066 -38300716 -40293708 -37949928 -42551448 -44557569 -46405898 -47755754 -48668011 -51181329 -50844780 -52495065 -52523705 -48871121 -53690604 -5145...
result:
wrong answer 1st numbers differ - expected: '0', found: '-614510'
Test #7:
score: 0
Wrong Answer
time: 159ms
memory: 21060kb
input:
100000 100000 1 2 76 1 3 842 1 4 532 1 5 416 2 6 353 3 7 770 4 8 416 5 9 241 6 10 682 7 11 639 8 12 302 9 13 785 10 14 784 11 15 607 12 16 889 13 17 792 14 18 891 15 19 663 16 20 88 17 21 854 18 22 681 19 23 95 20 24 81 21 25 175 22 26 329 23 27 558 24 28 422 25 29 850 26 30 919 27 31 674 28 32 474 ...
output:
-5385333527 -5344288909 -18055549135 -20574445465 -29644186567 -30496188228 -33479510810 -33023572462 -25483372854 -28963432797 -30586041339 -25767045167 -26311561922 -27675897542 -28227975222 -36320553597 -36524772834 -41935262118 -43142752076 -47659499456 -46898789981 -35038345853 -35065625349 -33...
result:
wrong answer 1st numbers differ - expected: '0', found: '-5385333527'
Test #8:
score: 0
Wrong Answer
time: 82ms
memory: 18248kb
input:
100000 100000 1 2 788 1 3 928 2 4 165 2 5 545 3 6 762 3 7 259 4 8 786 4 9 494 5 10 881 5 11 172 6 12 371 6 13 908 7 14 884 7 15 398 8 16 995 8 17 914 9 18 464 9 19 684 10 20 300 10 21 706 11 22 398 11 23 134 12 24 818 12 25 927 13 26 557 13 27 323 14 28 344 14 29 394 15 30 990 15 31 819 16 32 904 16...
output:
-53119668 -49140636 -15594061 -13251361 -29908399 -4775129 -28517010 -30049422 -31199747 -25949042 -33003554 -38106912 -38894736 -42009720 -38753964 -34618844 -38730055 -44075197 -46464905 -47485799 -49595299 -48558610 -51821714 -50178413 -53997368 -47065073 -48590105 -51012910 -55630450 -67853789 -...
result:
wrong answer 1st numbers differ - expected: '0', found: '-53119668'
Test #9:
score: 0
Wrong Answer
time: 94ms
memory: 21568kb
input:
100000 100000 1 2 494 2 3 30 3 4 81 4 5 890 5 6 547 6 7 811 7 8 245 8 9 175 9 10 126 10 11 871 11 12 826 12 13 705 13 14 527 14 15 360 15 16 447 16 17 800 17 18 794 18 19 340 19 20 789 20 21 335 21 22 873 22 23 826 23 24 770 24 25 537 25 26 591 26 27 523 27 28 455 28 29 599 29 30 912 30 31 789 31 32...
output:
270855592 1516196674 4130617762 5570285050 7851626200 11910209806 19446638488 23035672796 28350412304 33702310229 34183484615 34853662855 36129368665 38633832159 40165139153 43494191657 45663120641 45736446074 48106746266 50835813094 51386044829 51986216405 53711564359 55780868203 56328770872 596798...
result:
wrong answer 1st numbers differ - expected: '0', found: '270855592'
Test #10:
score: 0
Wrong Answer
time: 97ms
memory: 21576kb
input:
100000 100000 1 2 386 2 3 954 3 4 980 4 5 584 5 6 346 6 7 854 7 8 763 8 9 824 9 10 909 10 11 174 11 12 635 12 13 498 13 14 578 14 15 468 15 16 248 16 17 739 17 18 175 18 19 531 19 20 93 20 21 939 21 22 795 22 23 250 23 24 54 24 25 124 25 26 273 26 27 758 27 28 597 28 29 279 29 30 149 30 31 869 31 32...
output:
56316368 232726904 4644814453 4780983003 9195155531 14145803289 14709549481 16619103736 18548644458 18957723810 19152779888 19233913388 25089433810 26059443086 31641210838 31888209373 33319368043 34357773092 35023021996 38114964286 39410874451 41727467387 45361208648 45955761448 46488420562 46952584...
result:
wrong answer 1st numbers differ - expected: '0', found: '56316368'
Test #11:
score: 0
Wrong Answer
time: 93ms
memory: 21744kb
input:
100000 100000 1 2 126 2 3 500 3 4 234 4 5 710 5 6 254 6 7 818 7 8 959 8 9 242 9 10 768 10 11 479 11 12 5 12 13 453 13 14 774 14 15 371 15 16 170 16 17 685 17 18 202 18 19 992 19 20 647 20 21 307 21 22 925 22 23 410 23 24 328 24 25 153 25 26 807 26 27 719 27 28 590 28 29 812 29 30 515 30 31 778 31 32...
output:
21715110 1406815452 5489676992 5954439095 6316656956 12993166606 16253202262 20760373692 21676554616 21943674196 30831006604 31682677824 35829852654 39889175299 40230336259 41971219231 45490096117 46305475877 51906315002 54350070110 55632701755 56175294295 56345858577 58303808001 63956262185 6764253...
result:
wrong answer 1st numbers differ - expected: '0', found: '21715110'
Test #12:
score: 0
Wrong Answer
time: 102ms
memory: 21480kb
input:
100000 100000 1 2 949 2 3 876 3 4 748 4 5 477 5 6 381 6 7 771 7 8 32 8 9 235 9 10 81 10 11 184 11 12 358 12 13 786 13 14 421 14 15 673 15 16 841 16 17 184 17 18 556 18 19 350 19 20 930 20 21 584 21 22 882 22 23 109 23 24 189 24 25 160 25 26 883 26 27 817 27 28 234 28 29 150 29 30 817 30 31 254 31 32...
output:
14914754 316568469 2297578023 12477820910 12685401396 13735840849 17479702607 23842737059 29064225726 30815140962 31001993336 34061111174 34334890930 34634390449 42713622199 42716604439 45217694709 46582934277 46754422857 49278002499 53831362834 55460947464 57574327478 61794014166 65552408606 656379...
result:
wrong answer 1st numbers differ - expected: '0', found: '14914754'
Test #13:
score: 0
Wrong Answer
time: 92ms
memory: 21452kb
input:
100000 100000 1 2 973 2 3 609 3 4 712 4 5 864 5 6 415 6 7 296 7 8 367 8 9 407 9 10 987 10 11 396 11 12 942 12 13 406 13 14 109 14 15 178 15 16 95 16 17 60 17 18 647 18 19 895 19 20 347 20 21 857 21 22 887 22 23 800 23 24 280 24 25 166 25 26 144 26 27 929 27 28 138 28 29 118 29 30 408 30 31 703 31 32...
output:
517795344 2986423554 3201529924 11975689265 17548744047 23872209650 24618596444 24874846100 25122069806 28451567138 30403304975 31011403361 34047097484 34502740045 35488629517 35808960669 37588741881 38499219094 39637600822 40624011002 43224424448 43444811208 43499042957 46221421517 50635837391 5239...
result:
wrong answer 1st numbers differ - expected: '0', found: '517795344'
Test #14:
score: 0
Wrong Answer
time: 98ms
memory: 21700kb
input:
100000 100000 1 2 249 2 3 541 3 4 679 4 5 789 5 6 301 6 7 218 7 8 281 8 9 730 9 10 906 10 11 54 11 12 568 12 13 610 13 14 445 14 15 120 15 16 370 16 17 214 17 18 876 18 19 701 19 20 935 20 21 227 21 22 492 22 23 280 23 24 627 24 25 1 25 26 451 26 27 163 27 28 554 28 29 759 29 30 386 30 31 150 31 32 ...
output:
633811563 3903652898 8763933648 12011760348 13032719190 12089264250 16354152974 16667577791 20629109087 21571802299 23497456315 26960658547 30944133483 32317243949 33025021409 35105925330 35256119442 39699855984 42299776164 42831407812 49201689016 49488824350 56795047660 57042486272 58523728762 5964...
result:
wrong answer 1st numbers differ - expected: '0', found: '633811563'
Test #15:
score: 0
Wrong Answer
time: 100ms
memory: 21576kb
input:
100000 100000 1 2 24 2 3 258 3 4 408 4 5 587 5 6 611 6 7 919 7 8 412 8 9 229 9 10 579 10 11 931 11 12 77 12 13 824 13 14 174 14 15 492 15 16 513 16 17 904 17 18 903 18 19 147 19 20 219 20 21 753 21 22 578 22 23 658 23 24 288 24 25 816 25 26 592 26 27 988 27 28 433 28 29 643 29 30 392 30 31 663 31 32...
output:
1293980 1112340896 1664738426 1739707892 6531144104 7867099654 8399812368 10687938714 14093763156 21152948949 21658394719 22521591127 25125070303 25829077867 30152913835 30402206735 30954519815 34844805335 36221293339 37269960483 38988660650 39212961265 41250114964 46504687742 47026567752 4821104413...
result:
wrong answer 1st numbers differ - expected: '0', found: '1293980'
Test #16:
score: 0
Wrong Answer
time: 96ms
memory: 21420kb
input:
100000 100000 1 2 567 2 3 812 3 4 146 4 5 65 5 6 419 6 7 86 7 8 920 8 9 832 9 10 130 10 11 53 11 12 894 12 13 247 13 14 137 14 15 712 15 16 282 16 17 393 17 18 618 18 19 535 19 20 799 20 21 227 21 22 355 22 23 181 23 24 767 24 25 350 25 26 42 26 27 710 27 28 378 28 29 428 29 30 595 30 31 234 31 32 6...
output:
4034160 2177012225 2194379308 2482790396 5528031560 11441810984 14845487282 15662789528 18142308453 20793387009 21734565600 22926760367 23498494457 28881671498 33466381730 35548819780 36227199293 39321445139 41023802715 41826891183 48209811873 48415595003 49936360433 52333141693 49287810201 54933836...
result:
wrong answer 1st numbers differ - expected: '0', found: '4034160'
Test #17:
score: 0
Wrong Answer
time: 95ms
memory: 21576kb
input:
100000 100000 1 2 408 2 3 524 3 4 486 4 5 497 5 6 598 6 7 638 7 8 752 8 9 365 9 10 217 10 11 192 11 12 711 12 13 282 13 14 659 14 15 134 15 16 240 16 17 128 17 18 651 18 19 975 19 20 113 20 21 159 21 22 861 22 23 111 23 24 957 24 25 814 25 26 386 26 27 25 27 28 791 28 29 446 29 30 151 30 31 790 31 3...
output:
13534600 1399126803 7270101859 8136230269 10099074145 10107173470 12115173976 12840194833 12847592553 13786545768 14193696330 15370868430 15990350508 17534784420 21958612136 28151491283 34651297376 36517129648 40951852893 51515800593 52969511703 54562332018 57442597692 58232282200 63418598584 637047...
result:
wrong answer 1st numbers differ - expected: '0', found: '13534600'
Test #18:
score: 0
Wrong Answer
time: 101ms
memory: 21468kb
input:
100000 100000 1 2 716 2 3 57 3 4 220 4 5 368 5 6 120 6 7 843 7 8 313 8 9 211 9 10 444 10 11 886 11 12 40 12 13 811 13 14 938 14 15 14 15 16 745 16 17 725 17 18 247 18 19 592 19 20 92 20 21 483 21 22 645 22 23 393 23 24 294 24 25 247 25 26 25 26 27 667 27 28 432 28 29 852 29 30 644 30 31 694 31 32 86...
output:
17965985 2237339292 2634695610 2669955255 4905770463 5435138703 10172462474 9761457872 10693237592 16957963410 14896437032 17764029565 18369423997 17316749204 22332501914 27239418500 31725366302 36626049155 38405014915 39191905560 40088904744 41804177358 43662975033 43708431684 44800354560 457457423...
result:
wrong answer 1st numbers differ - expected: '0', found: '17965985'
Test #19:
score: 0
Wrong Answer
time: 93ms
memory: 21640kb
input:
100000 100000 1 2 405 2 3 375 3 4 830 4 5 199 5 6 993 6 7 711 7 8 797 8 9 864 9 10 402 10 11 809 11 12 852 12 13 250 13 14 5 14 15 268 15 16 403 16 17 63 17 18 589 18 19 502 19 20 568 20 21 663 21 22 922 22 23 605 23 24 824 24 25 585 25 26 169 26 27 951 27 28 65 28 29 116 29 30 71 30 31 561 31 32 31...
output:
104818120 2923495323 5341277493 6204928484 8064672209 12084464081 12046305567 15223354013 15831853903 16423512921 18105551145 18341640867 19941481692 20325072384 22853364280 26959030642 27787532127 35468872519 36105892819 40324747039 41493368159 42213715774 45138676174 47745897386 49183197108 494873...
result:
wrong answer 1st numbers differ - expected: '0', found: '104818120'
Test #20:
score: 0
Wrong Answer
time: 94ms
memory: 21500kb
input:
100000 100000 1 2 246 2 3 34 3 4 21 4 5 38 5 6 476 6 7 769 7 8 511 8 9 127 9 10 165 10 11 71 11 12 638 12 13 416 13 14 29 14 15 681 15 16 594 16 17 708 17 18 560 18 19 948 19 20 433 20 21 773 21 22 963 22 23 302 23 24 194 24 25 676 25 26 414 26 27 229 27 28 790 28 29 474 29 30 517 30 31 279 31 32 53...
output:
1382329600 2068255596 2113456260 1920339970 4817386830 6527282542 6768454642 7308316730 9221962241 10042815491 13011152146 13296334770 20168111448 21494761824 26956230564 26020863505 26886991663 27663626578 32945456745 37035255120 38063445380 39858346884 44082674291 47563150421 48296103054 538013514...
result:
wrong answer 1st numbers differ - expected: '0', found: '1382329600'