Submission #13069

#TimeUsernameProblemLanguageResultExecution timeMemory
13069dohyun0324K blocks (IZhO14_blocks)C++98
100 / 100
170 ms45620 KiB
#include<stdio.h> #include<algorithm> using namespace std; int mini,n,k,a[100010],top,d[110][100010]; struct data{ int x,mini,p; }st[100010]; int main() { int i,j; scanf("%d %d",&n,&k); for(i=1;i<=n;i++) scanf("%d",&a[i]); for(i=1;i<=n;i++) d[1][i]=max(d[1][i-1],a[i]); for(i=2;i<=k;i++){ top=0; d[i][0]=2147483647; for(j=i;j<=n;j++){ mini=2147483647; while(st[top].x<=a[j] && top>0){ mini=min(mini,st[top].mini); top--; } top++; st[top].mini=min(mini,d[i-1][j-1]); d[i][j]=min(d[i][st[top-1].p],st[top].mini+a[j]); st[top].x=a[j]; st[top].p=j; } } printf("%d",d[k][n]); 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...