1 条题解

  • 1
    @ 2021-8-8 1:49:56

    C++ :

    #include<cstdio>
    #include<iostream>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    const int MAXN=50010;
    int a[MAXN],tot,ans;
    void unions(int x){
        int tmp=a[x]+a[x-1];
        ans+=tmp;
        for(int i=x;i<tot;i++) a[i]=a[i+1];
        int j;
        for(j=x-1;a[j-1]<tmp && j>1;j--)
            a[j]=a[j-1];
        a[j]=tmp;
        tot--;
        for(int d=tot-j;j>2&&a[j-2]<=a[j];d=tot-j){
            unions(j-1);
            j=tot-d;
        }
    }
    int main() {
    	int n;
        while(scanf("%d",&n)&&n){
            ans=tot=0;
            for(int i=1;i<=n;i++)scanf("%d",&a[i]);
            for(int i=1;i<=n;i++){
                a[++tot]=a[i];
                while(tot>2 && a[tot-2]<=a[tot])unions(tot-1);
            }
            while (tot>1) unions(tot);
            printf("%d\n",ans);
        }
        return 0;
    }
     
    
    • 1

    信息

    ID
    216
    时间
    1000ms
    内存
    128MiB
    难度
    8
    标签
    递交数
    12
    已通过
    11
    上传者