Submission #1239128

#TimeUsernameProblemLanguageResultExecution timeMemory
1239128MasterDebaterK blocks (IZhO14_blocks)C++20
0 / 100
45 ms82568 KiB
#include<bits/stdc++.h> using namespace std; #define ll long long #define pii pair<ll,ll> #define F first #define S second const ll N=1e5+5,K=1e2+5,off=(1<<17),INF=1e18; ll n,k,a[N],nxt[N],dp[N][K]; vector<pii>v; ll solve(int i,int j){ if(i==n){ if(j==k)return 0; return INF; } if(j==k)return INF; if(dp[i][j]==-1){ //cout<<i<<' '<<j<<'\n'; dp[i][j]=INF; dp[i][j]=min(a[i]+solve(i+1,j+1),solve(nxt[i],j)); } return dp[i][j]; } int main(){ cin>>n>>k; for(int i=0;i<n;i++)cin>>a[i]; v.push_back({n,INF}); for(int i=n-1;i>=0;i--){ while(!v.empty() and v.back().S<a[i])v.pop_back(); //cout<<"----------------\n"; //for(int j=0;j<v.size();j++)cout<<v[j].F<<' '<<v[j].S<<'\n'; nxt[i]=v.back().F; v.push_back({i,a[i]}); } //for(int i=0;i<n;i++)cout<<nxt[i]<<' '; //cout<<'\n'; for(int i=0;i<N;i++)for(int j=0;j<K;j++)dp[i][j]=-1; cout<<solve(0,0); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...