제출 #754369

#제출 시각아이디문제언어결과실행 시간메모리
754369DJeniUpShortcut (IOI16_shortcut)C++17
0 / 100
1 ms340 KiB
#include "shortcut.h" #include "bits/stdc++.h" using namespace std; typedef long long ll; typedef pair<ll,ll>pairll; #define N 100007 #define INF 1000000000007 #define fr first #define sc second ll a[10*N],b[10*N],a1[10*N],b1[10*N],t[10*N],ma[10*N],mb[10*N],h[3007][3007]; priority_queue<pairll>q,q1; long long find_shortcut(int n, std::vector<int> k, std::vector<int> d, int c) { for(int i=1;i<n;i++){ a[i]=k[i-1]; b[i]=d[i-1]; t[i]=t[i-1]+a[i-1]; ma[i]=max(ma[i-1],a1[i-1]+a[i-1]+b[i]); a1[i]=max(a1[i-1]+a[i-1],b[i]); } b[n]=d[n-1]; t[n]=t[n-1]+a[n-1]; ma[n]=max(ma[n-1],a1[n-1]+a[n-1]+b[n]); a1[n]=max(a1[n-1]+a[n-1],b[n]); for(int i=n;i>=1;i--){ mb[i]=max(mb[i+1],b1[i+1]+a[i]+b[i]); b1[i]=max(b[i],b1[i+1]+a[i]); } for(int i=1;i<=n;i++){ for(int j=i;j<=n;j++){ h[i][i]=max(h[i][j],b[i]); for(int k1=i;k1<=j;k1++){ for(int k2=j;k2>k1;k2--){ if(t[k2]-t[k1]>t[j]-t[i]-(t[k2]-t[k1])+c){ h[i][j]=max(h[i][j],t[j]-t[i]-(t[k2]-t[k1])+c+b[k1]+b[k2]); }else{ h[i][j]=max(h[i][j],t[k2]-t[k1]+b[k1]+b[k2]); } //cout<<k1<<" "<<k2<<" "<<i<<" "<<j<<" "<<t[k2]-t[k1]+b[k1]+b[k2]<<" "<<t[j]-t[k2]+(t[k1]-t[i])+c+b[k1]+b[k2]<<endl; } } //cout<<h[i][j]<<" "<<i<<" "<<j<<endl; } } b[n]=d[n-1]; //ll prew=INF; ll res=ma[n]; // cout<<res<<endl; for(int l=1;l<=n;l++){ ll mx=0; ll mx2=0; while(q.size()>0)q.pop(); while(q1.size()>0)q1.pop(); q.push({b[l]-t[l],l}); q1.push({b[l]-t[l]+c,l}); for(int r=l+1;r<=n;r++){ q.push({b[r]-t[r],r}); q1.push({b[r]-t[r]+c,r}); while(q.size()>0 && t[q.top().sc]-t[l]+b[q.top().sc]+c<q.top().fr+t[r]){ mx=max(mx,t[q.top().sc]-t[l]+b[q.top().sc])+c; q.pop(); } while(q1.size()>0 && t[q1.top().sc]-t[l]+b[q1.top().sc]<q1.top().fr+t[r]){ mx2=max(mx,t[q1.top().sc]-t[l]+b[q1.top().sc]); q1.pop(); } res=min(res,max(max(ma[l],mb[r]),max(max(h[l][r],max(a1[l-1]+a[l-1]+max(mx2,q1.top().fr+t[r]),b1[r+1]+a[r]+max(mx,q.top().fr+t[r]))),min(ll(c),t[r]-t[l])+a1[l]+b1[r]))); //cout<<l<<" "<<r<<" "<<res<<endl; } } return 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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...