Submission #13068

#TimeUsernameProblemLanguageResultExecution timeMemory
13068dohyun0324K blocks (IZhO14_blocks)C++98
0 / 100
1 ms45228 KiB
#include<stdio.h>
#include<algorithm>
using namespace std;
int mini,n,k,a[100010],top,d[110][100010];
struct data{
    int x,mini;
}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;
        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]=st[top].mini+a[j];
            st[top].x=a[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...