Submission #823442

#TimeUsernameProblemLanguageResultExecution timeMemory
823442I_Love_EliskaM_Sky Walking (IOI19_walk)C++17
0 / 100
61 ms4676 KiB
#include "walk.h" #include <bits/stdc++.h> using namespace std; #define forn(i,n) for(int i=0; i<n; ++i) #define pb push_back using ll = int64_t; const ll inf = 4e18; #define pi pair<ll,ll> #define f first #define s second #define all(x) x.begin(), x.end() #define rall(x) x.rbegin(),x.rend() #define int ll const int sz=1<<30; struct sgt { sgt *L, *R; int s; sgt() { L=R=NULL; s=inf; } void set(int l, int r, int i, int x) { if (r-l==1) { s=x; return; } int m=(l+r)>>1; if (i<m) { if (!L) L=new sgt(); L->set(l,m,i,x); } else { if (!R) R=new sgt(); R->set(m,r,i,x); } s = min(L?L->s:inf, R?R->s:inf); } void set(int i, int x) { set(0,sz,i,x); } int query(int l, int r, int lx, int rx) { if (rx<=l || r<=lx) return inf; if (lx<=l && r<=rx) return s; int m=(l+r)>>1; int lq=L?L->query(l,m,lx,rx):inf; int rq=R?R->query(m,r,lx,rx):inf; return min(lq,rq); } int query(int l, int r) { return query(0,sz,l,r); } }; #undef int long long min_distance(vector<int>x, vector<int>h, vector<int>l, vector<int>r, vector<int>y, int s, int g) { int n=x.size(), m=l.size(); #define int ll sgt st; forn(i,n) st.set(i,-h[i]); sgt bottom, top; bottom.set(0,0); top.set(0,0); vector<vector<int>> del(n); vector<vector<pi>> add(n); del[0].pb(0); add[n-1].pb({0,0}); forn(i,m) { add[l[i]].pb({y[i],-st.query(l[i],r[i]+1)}); del[r[i]].pb(y[i]); } forn(i,n) { vector<pi> toset; for(auto&it:add[i]) { int y=it.f, z=it.s; int f = bottom.query(0,y+1); int s = top.query(y,z+1); if (min(f,s)==inf) continue; f+=y; s-=y; int x=min(f,s); toset.pb({y,x}); } for(auto&y:del[i]) { bottom.set(y,inf); top.set(y,inf); } for(auto&x:toset) { bottom.set(x.f,x.s-x.f); top.set(x.f,x.s+x.f); } } if (top.s==inf) return -1; int f = top.s+x[n-1]-x[0]; return f; #undef int }
#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...