제출 #772634

#제출 시각아이디문제언어결과실행 시간메모리
772634I_Love_EliskaM_자리 배치 (IOI18_seats)C++14
0 / 100
4046 ms67596 KiB
#include "seats.h" #include <bits/stdc++.h> using namespace std; #define forn(i,n) for(int i=0;i<n;++i) #define pi pair<int,int> #define f first #define s second const int inf=1e9; vector<int> r, c; int n,m; struct sgt { vector<int> mn,mx; int sz=1; sgt(int n) { while (sz<n) sz<<=1; mn.assign(2*sz-1,inf); mx.assign(2*sz-1,0); } void upd(int v, int l, int r, int i) { if (r-l==1) return; int m=(l+r)>>1; if (i<m) upd(2*v+1,l,m,i); else upd(2*v+2,m,r,i); mn[v]=min(mn[2*v+1],mn[2*v+2]); mx[v]=max(mx[2*v+1],mx[2*v+2]); } void set(int i, int x) { mn[sz-1+i]=mx[sz-1+i]=x; upd(0,0,sz,i); } pi query(int v, int l, int r, int lx, int rx) { if (rx<=l || r<=lx) return {inf,-inf}; if (lx<=l && r<=rx) return {mn[v],mx[v]}; int m=(l+r)>>1; auto lq = query(2*v+1,l,m,lx,rx); auto rq = query(2*v+2,m,r,lx,rx); return { min(lq.f,rq.f) , max(lq.s,rq.s) }; } pi query(int l, int r) { return query(0,0,sz,l,r); } int qmin(int l, int r) { auto q = query(0,0,sz,l,r); return q.f; } int qmax(int l, int r) { auto q = query(0,0,sz,l,r); return q.s; } }; sgt stx(1e6), sty(1e6); void give_initial_chart(int N, int M, vector<int> R, vector<int> C) { r=R, c=C; n=N, m=M; forn(i,n*m) stx.set(i,r[i]), sty.set(i,c[i]); //forn(i,n*m) cout<<stx.qmin(0,i+1)<<' '; cout<<'\n'; //forn(i,n*m) cout<<stx.qmax(0,i+1)<<' '; cout<<'\n'; //forn(i,n*m) cout<<sty.qmin(0,i+1)<<' '; cout<<'\n'; //forn(i,n*m) cout<<sty.qmax(0,i+1)<<' '; cout<<'\n'; } int swap_seats(int x, int y) { swap(r[x],r[y]); swap(c[x],c[y]); stx.set(x,r[x]); stx.set(y,r[x]); sty.set(x,c[x]); sty.set(y,c[y]); int u=n-1, d=0, lx=m-1, rx=0; forn(i,n*m) { u=min(u,r[i]); d=max(d,r[i]); lx=min(lx,c[i]); rx=max(rx,c[i]); assert((rx-lx+1)*(d-u+1) >= i+1); assert(u==stx.qmin(0,i+1)); } return 0; int ans=0; int i=1; int it=0; while (i<=n*m) { ++it; auto q = stx.query(0,i); int u = q.f; int d = q.s; q = sty.query(0,i); int l=q.f; int r=q.s; assert( (r-l+1)*(d-u+1) >= i ); if ( (r-l+1)*(d-u+1) == i ) { ++ans; ++i; } else { i = (r-l+1)*(d-u+1); } } assert(it<=2*(n+m)); return ans; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...