Submission #19052

#TimeUsernameProblemLanguageResultExecution timeMemory
19052tlwpdusGame (IOI13_game)C++98
63 / 100
3327 ms256000 KiB
#include "game.h" #include<algorithm> #include<stdio.h> long long gcd2(long long X, long long Y) { long long tmp; while (X != Y && Y != 0) { tmp = X; X = Y; Y = tmp % Y; } return X; } typedef long long ll; int R, C; struct node { node *l, *r; ll val; node() { l=r=NULL; val = 0; } void update(int idx, ll num, int s=0, int e=R-1) { if (s==e) { val = num; return; } int m = (s+e)>>1; if (m<idx) { if (!r) r=new node(); r->update(idx,num,m+1,e); } else { if (!l) l=new node(); l->update(idx,num,s,m); } val = gcd2((l)?l->val:0,(r)?r->val:0); } ll query(int S, int E, int s=0, int e=R-1) { if (s>E||S>e) return 0; if (S<=s&&e<=E) { return val; } int m = (s+e)>>1; return gcd2((l)?l->query(S,E,s,m):0,(r)?r->query(S,E,m+1,e):0); } }; void hap(node *a, node *b, node *c, int idx, int s, int e) { // a+b->c if (s==e) { c->val = gcd2(a->val,b->val); return; } int m = (s+e)>>1; if (m<idx) { if (!a->r) a->r=new node(); if (!b->r) b->r=new node(); if (!c->r) c->r=new node(); hap(a->r,b->r,c->r,idx,m+1,e); } else { if (!a->l) a->l=new node(); if (!b->l) b->l=new node(); if (!c->l) c->l=new node(); hap(a->l,b->l,c->l,idx,s,m); } c->val = gcd2(a->val,b->val); } struct segnode { segnode *l, *r; node *root; segnode() { l=r=NULL; root=new node(); } void update(int idx, int idy, ll num, int s=0, int e=C-1) { if (s==e) { root->update(idx,num); return; } int m = (s+e)>>1; if (!r) r=new segnode(); if (!l) l=new segnode(); if (m<idy) { r->update(idx,idy,num,m+1,e); } else { l->update(idx,idy,num,s,m); } hap(l->root,r->root,root,idx,0,R-1); } ll query(int p, int q, int u, int v, int s=0, int e=C-1) { if (s>v||q>e) return 0; if (q<=s&&e<=v) { return root->query(p,u); } int m = (s+e)>>1; return gcd2((l)?l->query(p,q,u,v,s,m):0,(r)?r->query(p,q,u,v,m+1,e):0); } } seg; void init(int r, int c) { R=r; C=c; } void update(int P, int Q, long long K) { seg.update(P,Q,K); } long long calculate(int P, int Q, int U, int V) { return seg.query(P,Q,U,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...