Submission #1013377

#TimeUsernameProblemLanguageResultExecution timeMemory
1013377amirhoseinfar1385Game (IOI13_game)C++17
0 / 100
503 ms14420 KiB
#include "game.h" #include<bits/stdc++.h> using namespace std; const int ted=20000000; int kaf=1000000000+1; int n,m; long long gcd(long long a,long long b){ if(a==0){ return b; } if(b==0){ return a; } return gcd(b,a%b); } long long gc[ted]; int cl[ted],cr[ted]; bitset<ted>lnk; int te; void gotime(){ int z=1e6; for(int i=0;i<100000000000;i++){ z=sqrt(z); z+=23476; } cout<<z<<endl; } void init(int R, int C) { //hehe te=2; cl[0]=cl[1]=cr[0]=cr[1]=-1; lnk[0]=1; } int getr(int u){ if(cr[u]==-1){ if(lnk[u]==0){ cr[u]=te; cl[te]=cr[te]=-1; te++; }else{ cr[u]=te; lnk[te]=1; cl[te]=cr[te]=-1; cl[te+1]=cr[te+1]=-1; te+=2; } } if(te>=ted){ gotime(); } return cr[u]; } int getl(int u){ if(cl[u]==-1){ if(lnk[u]==0){ cl[u]=te; cl[te]=cr[te]=-1; te++; }else{ cl[u]=te; lnk[te]=1; cl[te]=cr[te]=-1; cl[te+1]=cr[te+1]=-1; te+=2; } } if(te>=ted){ gotime(); } return cl[u]; } void asl(int u1,int u2,int u3,int l,int r,int tr){ if(l>r||!(tr>=l&&tr<=r)){ return ; } if(u2==-1){ gc[u1]=gc[u3]; }else if(u3==-1){ gc[u1]=gc[u2]; }else{ gc[u1]=gcd(gc[u2],gc[u3]); } if(l==r){ return; } if(u2==-1){ gc[u1]=gc[u3]; cl[u1]=cl[u3]; cr[u1]=cr[u3]; return; }else if(u3==-1){ gc[u1]=gc[u2]; cl[u1]=cl[u2]; cr[u1]=cr[u2]; return ; }else if(cl[u1]==cl[u2]||cl[u1]==cl[u3]){ cl[u1]=cr[u1]=-1; gc[u1]=gcd(gc[u2],gc[u3]); } int m=(l+r)>>1; int l2,l3,r2,r3; if(u2==-1||cl[u2]==-1){ l2=-1; }else{ l2=cl[u2]; } if(u3==-1||cl[u3]==-1){ l3=-1; }else{ l3=cl[u3]; } if(u2==-1||cr[u2]==-1){ r2=-1; }else{ r2=cr[u2]; } if(u3==-1||cr[u3]==-1){ r3=-1; }else{ r3=cr[u3]; } if(tr<=m){ /* if(l2==-1){ cl[u1]=l3; return ; } if(l3==-1){ cl[u1]=l2; return ; } if(cl[u1]==l2||cl[u1]==l3){ cl[u1]=-1; }*/ asl(getl(u1),l2,l3,l,m,tr); }else{ /*if(r2==-1){ cr[u1]=r3; return ; } if(r3==-1){ cr[u1]=r2; return ; } if(cr[u1]==r2||cr[u1]==r3){ cr[u1]=-1; }*/ asl(getr(u1),r2,r3,m+1,r,tr); } } void calc(int u,int tr){ if(lnk[u]==0){ return ; } int cll=cl[u]; int crr=cr[u]; asl(u+1,cll+1,crr+1,0,kaf-1,tr); } void upd(int u,int l,int r,int tl,int tr,long long w){ if(l>r||l>tl||r<tl){ return ; } if(l==r){ if(lnk[u]==0){ gc[u]=w; }else{ upd(u+1,0,kaf-1,tr,tl,w); } return ; } int m=(l+r)>>1; if(tl<=m){ upd(getl(u),l,m,tl,tr,w); }else{ upd(getr(u),m+1,r,tl,tr,w); } if(lnk[u]==1){ calc(u,tr); }else{ if(cl[u]==-1){ gc[u]=gc[cr[u]]; }else if(cr[u]==-1){ gc[u]=gc[cl[u]]; }else{ gc[u]=gcd(gc[getl(u)],gc[getr(u)]); } } } long long pors(int u,int l,int r,int tl,int tr,int tl2,int tr2){ if(u==-1||l>r||l>tr||r<tl||tl>tr){ return 0; } if(l>=tl&&r<=tr){ if(lnk[u]==0){ return gc[u]; }else{ return pors(u+1,0,kaf-1,tl2,tr2,tl,tr); } } int m=(l+r)>>1; return gcd(pors(cl[u],l,m,tl,tr,tl2,tr2),pors(cr[u],m+1,r,tl,tr,tl2,tr2)); } void update(int P,int Q, long long K) { upd(0,0,kaf-1,P,Q,K); } long long calculate(int P,int Q,int U,int V) { return pors(0,0,kaf-1,P,U,Q,V); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...