This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#include "game.h"
using namespace std;
int n,cm;
struct xnod
{
xnod(int tl,int tr):tl(tl),tr(tr),l(NULL),r(NULL),value(0LL){}
xnod *l,*r;
int tl,tr;
long long int value;
};
struct ynod
{
ynod():l(NULL),r(NULL),xst(0,n-1){}
ynod *l,*r;
xnod xst;
};
ynod *root;
void init(int R,int C)
{
n=R;
cm=C;
root=new ynod();
}
void updatex(xnod *nod,int vx,long long int k)
{
int l=nod->tl,r=nod->tr,m=(l+r)/2;;
if(l==r)
{
nod->value=k;
return;
}
xnod **koce=&(vx<=m?nod->l:nod->r);
if(*koce==NULL)
{
*koce=new xnod(vx,vx);
(*koce)->value=k;
}
else if((*koce)->tl<=vx&&vx<=(*koce)->tr)updatex(*koce,vx,k);
else
{
do
{
if(vx<=m)
{
r=m;
}
else
{
l=m+1;
}
m=(l+r)/2;
}while((vx<=m)==((*koce)->tr<=m));
xnod *temp=new xnod(l,r);
if((*koce)->tr<=m)temp->l=*koce;
else{temp->r=*koce;}
*koce=temp;
updatex(*koce,vx,k);
}
nod->value=gcd(nod->l?nod->l->value:0,nod->r?nod->r->value:0);
}
long long int queryx(xnod *nod,int vxl,int vxr)
{
if(nod==NULL||nod->tl>vxr||nod->tr<vxl)
{
return 0;
}
if(vxl<=nod->tl&&nod->tr<=vxr)
{
return nod->value;
}
return gcd(queryx(nod->l,vxl,vxr),queryx(nod->r,vxl,vxr));
}
long long int queryy(ynod *nod,int vyl,int vyr,int vxl,int vxr,int tl,int tr)
{
if(nod==NULL||tl>vyr||tr<vyl)return 0;
if(vyl<=tl&&tr<=vyr)
{
return queryx(&nod->xst,vxl,vxr);
}
int m=(tl+tr)/2;
return gcd(queryy(nod->l,vyl,vyr,vxl,vxr,tl,m),queryy(nod->r,vyl,vyr,vxl,vxr,m+1,tr));
}
void updatey(ynod *nod,int vx,int vy,long long int k,int tl,int tr)
{
if(tl==tr)
{
updatex(&nod->xst,vx,k);
}
int m=(tl+tr)/2;
if(vy<=m)
{
if(nod->l==NULL)nod->l=new ynod();
updatey(nod->l,vx,vy,k,tl,m);
}
else
{
if(nod->r==NULL)nod->r=new ynod();
updatey(nod->l,vx,vy,k,m+1,tr);
}
long long int k1=gcd(nod->l?queryx(&nod->l->xst,vx,vx):0,nod->l?queryx(&nod->r->xst,vx,vx):0);
updatex(&nod->xst,vy,k1);
}
long long int calculate(int r1,int r2,int c1,int c2)
{
return queryy(root,r2,c2,r1,c1,0,cm-1);
}
void update(int R,int C,long long int k)
{
updatey(root,R,C,k,0,cm-1);
}
Compilation message (stderr)
game.cpp: In constructor 'xnod::xnod(int, int)':
game.cpp:9:12: warning: 'xnod::tr' will be initialized after [-Wreorder]
9 | int tl,tr;
| ^~
game.cpp:8:11: warning: 'xnod* xnod::l' [-Wreorder]
8 | xnod *l,*r;
| ^
game.cpp:7:5: warning: when initialized here [-Wreorder]
7 | xnod(int tl,int tr):tl(tl),tr(tr),l(NULL),r(NULL),value(0LL){}
| ^~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |