Submission #819984

#TimeUsernameProblemLanguageResultExecution timeMemory
819984TimDeeWombats (IOI13_wombats)C++17
100 / 100
9581 ms185328 KiB
#include "wombats.h" #include <bits/stdc++.h> using namespace std; #define forn(i,n) for(int i=0;i<n;++i) #define pb push_back #define all(x) x.begin(), x.end() #define pi pair<int,int> #define f first #define s second const int inf=1e9; const int N=5120; const int C=205; int opt[C][C]; int n,c; int getopt(int i, int j) { if (i<0 || j<0) return 0; if (i>=c || j>=c) return c-1; return opt[i][j]; } struct sgt { struct node { int empty=1; vector<vector<int>> v; node() { empty=1; } }; vector<node> t; int sz=1; sgt(int n) { while (sz<n) sz<<=1; t.assign(2*sz,node()); } void merge(int v, int a, int b) { if (t[b].empty) { t[v]=t[a]; return; } if (t[a].empty) { t[v]=t[b]; return; } t[v].empty=0; t[v].v.assign(c,vector<int>(c,inf)); for (int k=-c+1; k<c; ++k) { for (int l=0; l<c; ++l) { int r = l-k; if (r<0 || r>=c) continue; for (int m=getopt(l-1,r); m<=getopt(l,r+1); ++m) { if (t[a].v[l][m]+t[b].v[m][r] < t[v].v[l][r]) { t[v].v[l][r] = t[a].v[l][m]+t[b].v[m][r]; opt[l][r] = m; } } } } } 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); merge(v,2*v+1,2*v+2); } void set(int i, vector<vector<int>>&v) { t[sz-1+i].v=v; t[sz-1+i].empty=0; upd(0,0,sz,i); } }; const int K=10; sgt st(N/K); int d[K*C][C]; int h[N][C]; int v[N][C]; bitset<2*C> vis; void work(int i) { vector<vector<int>> t(c,vector<int>(c,1e9)); if (i>=n-1) return; forn(i,K*c) forn(j,c) d[i][j]=inf; for(int j=i; j<min(i+K,n-1); ++j) { forn(p,c) { d[p+(j-i)*c][p]=0; for (int q=0; q<c-1; ++q) { d[p+(j-i)*c][q+1]=min(d[p+(j-i)*c][q+1],d[p+(j-i)*c][q]+h[j][q]); } for (int q=c-1; q>0; --q) { d[p+(j-i)*c][q-1]=min(d[p+(j-i)*c][q-1],d[p+(j-i)*c][q]+h[j][q-1]); } forn(q,c) d[p+(j-i)*c][q]+=v[j][q]; for (int q=0; q<c-1; ++q) { d[p+(j-i)*c][q+1]=min(d[p+(j-i)*c][q+1],d[p+(j-i)*c][q]+h[j+1][q]); } for (int q=c-1; q>0; --q) { d[p+(j-i)*c][q-1]=min(d[p+(j-i)*c][q-1],d[p+(j-i)*c][q]+h[j+1][q-1]); } } } auto f=t; auto s=f; forn(p,c) forn(q,c) s[p][q]=d[p][q]; for(int j=i+1; j<min(i+K,n-1); ++j) { forn(p,c) { forn(q,c) { if (s[p][q]+d[q+(j-i)*c][p] < f[p][p]) { f[p][p] = s[p][q]+d[q+(j-i)*c][p]; opt[p][p] = q; } } } for(int k=1; k<c; ++k) { for (int l=0; l+k<c; ++l) { int r=l+k; for (int m=opt[l][r-1]; m<=opt[l+1][r]; ++m) { if (s[l][m]+d[m+(j-i)*c][r] < f[l][r]) { f[l][r] = s[l][m]+d[m+(j-i)*c][r]; opt[l][r]=m; } } } } for(int k=1; k<c; ++k) { for (int l=0; l+k<c; ++l) { int r=l+k; for (int m=opt[r-1][l]; m<=opt[r][l+1]; ++m) { if (s[r][m]+d[m+(j-i)*c][l] < f[r][l]) { f[r][l] = s[r][m]+d[m+(j-i)*c][l]; opt[r][l]=m; } } } } s=f; f=t; } st.set(i/K,s); } void init(int _n, int _c, int _h[][200], int _v[][200]) { n=_n, c=_c; forn(i,n) forn(j,c-1) h[i][j]=_h[i][j]; forn(i,n-1) forn(j,c) v[i][j]=_v[i][j]; for (int i=0; i<n-1; i+=K) { work(i); } } void changeH(int i, int j, int w) { h[i][j]=w; work((i/K)*K); if ((i+1)/K*K != i/K*K) work((i+1)/K*K); if (i) if ((i-1)/K*K != i/K*K) work((i-1)/K*K); } void changeV(int i, int j, int w) { v[i][j]=w; work((i/K)*K); } int escape(int i, int j) { return st.t[0].v[i][j]; }

Compilation message (stderr)

grader.c: In function 'int main()':
grader.c:15:6: warning: variable 'res' set but not used [-Wunused-but-set-variable]
   15 |  int res;
      |      ^~~
#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...