Submission #15775

#TimeUsernameProblemLanguageResultExecution timeMemory
15775comet달리는 게임 (kriii3_E)C++98
70 / 70
515 ms33104 KiB
#include<iostream> #include<algorithm> #include<deque> using namespace std; typedef long long ll; ll s[1000010],d[1000010],d2[100],p[1000010],p2[1000010]; deque<ll> a,b,c; int cnt=0; void push(ll n,ll m){ int sz=a.size(); //cout<<"push"<<endl; //cout<<"n="<<n<<" "<<"m="<<m<<endl; //for(int i=0;i<a.size();i++)cout<<c[i]<<" "; //cout<<endl; while( sz>1 && (b[0]-b[1])*(a[0]-n) < (m-b[0])*(a[1]-a[0]) ){ //cout<<(double)(b[1]-b[0])/(a[0]-a[1])<<" "<<(double)(m-b[0])/(a[0]-n)<<endl; sz--; a.pop_front(); b.pop_front(); c.pop_front(); } //cout<<"push end"<<endl; a.push_front(n); b.push_front(m); c.push_front(cnt++); } ll query(ll x,ll y){ if(a.size()==1)return a[0]*x+b[0]+y; int lo=0,hi=a.size(),mid; while(lo+1<hi){ mid=(lo+hi)/2; if(b[mid]-b[mid-1]<x*(a[mid-1]-a[mid])){ hi=mid; } else{ lo=mid; } } //for(int i=0;i<a.size();i++)cout<<a[i]*x+b[i]+y<<",("<<c[i]<<") "; //cout<<"lo="<<lo<<endl; return a[lo]*x+b[lo]+y; } int main(){ ll n,ans=0; cin>>n; for(int i=1;i<=n;i++){ cin>>s[i]; p[i]=p[i-1]+s[i]; p2[i]=p2[i-1]+i*s[i]; } push(-1,-p2[1]+p[1]); for(ll i=1;i<=n;i++){ d[i]=p2[i]; d2[i]=p2[i]; //for(ll j=0;j<i;j++){ // d2[i]=max(d2[i], -(j+1)*p[i] +d2[j]-p2[j+1]+(j+1)*p[j+1] +p2[i] ); //} //cout<<d[i]<<" "<<d2[i]<<endl; d[i]=max(d[i],query(p[i],p2[i])); push(-(i+1),d[i]-p2[i+1]+(i+1)*p[i+1]); //cout<<d[i]<<" "<<d2[i]<<endl; //cout<<"i="<<i<<endl; } cout<<d[n]; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...