P1318 80pts 求助
  • 板块灌水区
  • 楼主dfydn
  • 当前回复0
  • 已保存回复0
  • 发布时间2021/9/27 21:11
  • 上次更新2023/11/4 05:29:52
查看原帖
P1318 80pts 求助
112048
dfydn楼主2021/9/27 21:11
#include<cstdio>
#include<iostream>
using namespace std;
const int N=10005;
int n;
int a[N];
int flag,l,r,ans;
int read(){
    int num=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9'){
        if(c=='-') f=-1;
        c=getchar();
    }
    while(c>='0'&&c<='9'){
        num=num*10+c-'0';
        c=getchar();
    }
    return num*f;
}
int main(){
    n=read();
    for(int i=1;i<=n;i++) a[i]=read();
    for(int i=1;i<=n;i++){
        if(!l){
            if(a[i]>=a[i-1]&&a[i]>a[i+1]){
                l=i;
            }
        }
        else{
            if(a[i]>a[i-1]&&a[i]>=a[i+1]){
                r=i;
                int full=min(a[l],a[r]);
                for(int i=l+1;i<=r-1;i++) ans+=full-a[i];
                for(int i=r;;i++){
                    if(a[i+1]==a[i]) r++;
                    else break;
                }
                l=r;
            }
        }
    }
    printf("%d",ans);
    return 0;
} 
2021/9/27 21:11
加载中...