80pts 求助
  • 板块P1318 积水面积
  • 楼主dfydn
  • 当前回复0
  • 已保存回复0
  • 发布时间2021/9/27 11:43
  • 上次更新2023/11/4 05:33:47
查看原帖
80pts 求助
112048
dfydn楼主2021/9/27 11:43
#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 11:43
加载中...