Submission #596426

#TimeUsernameProblemLanguageResultExecution timeMemory
596426DeepessonPeru (RMI20_peru)C++17
0 / 100
79 ms137460 KiB
#include <bits/stdc++.h> #define MAX 2500005 int solve(int n, int k, int* v); using ll = long long; typedef std::pair<ll,ll> pii; ll inf = 1LL<<60LL; ll dp[MAX]; ll cdp[MAX]; int N,K; ll array[MAX]; ll MOD = 1e9+7; ll expo[MAX]; ll gera_hash(void){ ll hash = 0; for(int i=0;i!=N;++i){ hash = (hash + (dp[i]*expo[N-1-i]))%MOD; } return hash; } ll tab[MAX*4]; ll lazy[MAX*4]; void propag(int x){ // if(x==4194305){std::cout<<"ALERTAAAAAAA!!!!\n"; // std::cout<<x<<" expande "<<lazy[x]<<" "<<tab[x]<<"\n";} tab[x]=std::min(inf,lazy[x]+tab[x]); if(x*2<MAX*4){ lazy[x*2]+=lazy[x]; lazy[(x*2)+1]+=lazy[x]; } lazy[x]=0; } void update(int t,int k,int la=0,int ra=MAX-1,int pos=1){ propag(pos); if(t>ra||t<la)return; if(la==ra){ // std::cout<<"ok "<<pos<<" "<<k<<"\n"; tab[pos]=k; return; } int m = (la+ra)/2; update(t,k,m+1,ra,(pos*2)+1); update(t,k,la,m,pos*2); tab[pos]=std::min(tab[pos*2],tab[(pos*2)+1]); // std::cout<<"kek "<<tab[pos]<<"\n"; } ll query(int l,int r,int la=0,int ra=MAX-1,int pos=1){ propag(pos); if(l>ra||r<la||tab[pos]==inf)return inf; if(la>=l&&ra<=r){ //std::cout<<"retorna "<<tab[pos]<<" "<<pos<<"\n"; return tab[pos]; } int m = (la+ra)/2; return std::min(query(l,r,m+1,ra,(pos*2)+1),query(l,r,la,m,pos*2)); } void lazyprop(int l,int r,ll k,int la=0,int ra=MAX-1,int pos=1){ propag(pos); if(l>ra||r<la||tab[pos]==inf)return; if(la>=l&&ra<=r){ lazy[pos]+=k; propag(pos); // std::cout<<"Add "<<k<<" "<<tab[pos]<<" "<<pos<<"\n"; return; } int m = (la+ra)/2; lazyprop(l,r,k,m+1,ra,(pos*2)+1); lazyprop(l,r,k,la,m,pos*2); tab[pos]=std::min(tab[pos*2],tab[(pos*2)+1]); } void add_seg(int l,int r,int k){ lazyprop(l,r,k); } int solve(int n, int k, int* array){ N=n; K=k; expo[0]=1; for(auto&x:tab)x=inf; for(int i=1;i!=MAX;++i)expo[i]=(23LL*expo[i-1])%MOD; for(auto&x:dp)x=inf; for(auto&x:cdp)x=inf; { ll max=0; for(int i=0;i!=K;++i){ max=std::max(max,(ll)array[i]); dp[i]=max; } } std::vector<pii> stack; for(int i=0;i!=N;++i){ pii ent = {array[i],i}; int last_r = i-1; while(stack.size()&&stack.back().first<=array[i]){ ll dif = array[i]-stack.back().first; add_seg(stack.back().second,last_r,dif); // std::cout<<"update "<<stack.back().second<<" "<<last_r<<" "<<dif<<"!\n"; last_r=stack.back().second-1; ent.second=stack.back().second; stack.pop_back(); } // ent.second=std::max(ent.second,(ll)i-K); stack.push_back(ent); ll ask = query(std::max(0,i-K),i); //std::cout<<"Ans "<<i<<" "<<ask<<"\n"; dp[i]=std::min(dp[i],ask); //std::cout<<"Envia "<<array[i]+dp[i]<<"\n"; update(i,array[i]+dp[i]); } // for(int i=0;i!=N;++i)std::cout<<dp[i]<<" \n"[i==N-1]; return gera_hash(); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...