【2020.10.29 洛谷团队赛 普及组】T3 U138026 土地恢复

102 篇文章 0 订阅
102 篇文章 1 订阅

题目描述
宣文胜的家乡山西省是我国的产煤大省,因为长期挖煤导致了他家乡的某些地方出现了地陷的情况。 近几年国家大力开展环境整治和土地复耕,让人民不仅享受经济发展所带来的红利更要还老百姓绿水 青山。为了把这些地陷的土地恢复平整,他的家乡决定聘请他负责这项工作。

他负责恢复的是一条长度为n的土地,恢复土地的主要工作是填平下陷的地表。需要恢复的土地可以 看作是n块首尾相连的区域,一开始,第i块区域下陷的深度为di。宣文胜决定每天选择一段连续区间 [M, N] ,填充这段区间中的每块区域,让其下陷深度减少1。在选择区间时,需要保证,区间内的每 块区域在恢复前下陷深度均不为0 。

宣文胜希望你能帮他设计一种方案,可以在最短的时间内将整块土地的下陷深度都变为0。


输入格式
第一行输入一个整数n,表示恢复土地的长度。
第二行n个整数di,以空格隔开。

输出格式
输出一个整数,即最少需要多少天才能完成任务。


输入输出样例
输入 #1
6
4 3 2 5 3 5
输出 #1
9

输入 #2
4
2 5 3 5
输出 #2
7

输入 #3
12
2 6 5 8 9 12 15 7 5 10 16 24
输出 #3
35


说明/提示
数据范围
对于60%的数据, 1 ≤ n ≤ 50 1 ≤ n ≤ 50 1n50;
对于80%的数据, 1 ≤ n ≤ 1000 1 ≤ n ≤ 1000 1n1000;
对于100%的数据, 1 ≤ n ≤ 100000 , 0 ≤ d i ≤ 10000 1 ≤ n ≤ 100000,0 ≤ di ≤ 10000 1n1000000di10000


样例解释
样例1解释说明:
一种可行的最佳方案是,依次选择:
[ 1 , 6 ] 、 [ 1 , 6 ] 、 [ 1 , 2 ] 、 [ 1 , 1 ] 、 [ 4 , 6 ] 、 [ 4 , 4 ] 、 [ 4 , 4 ] 、 [ 6 , 6 ] 、 [ 6 , 6 ] [1,6]、[1,6]、[1,2]、[1,1]、[4,6]、[4,4]、[4,4]、[6,6]、[6,6] [1,6][1,6][1,2][1,1][4,6][4,4][4,4][6,6][6,6]


解题思路
仔细观察,我们会发现,对于一个递减的序列,最大的那个数就是需要挖的天数。

SO,我们在统计过程中,若碰到一个数大于他前面的那个数,让序列不在递增,天数就加上他和他前面的那个数的差,以当前的数为新的递增序列的头。


代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cmath>
#include<algorithm>
#include<queue>
using namespace std;
int n,d[101000],ans;
int main() {
	scanf("%d",&n);
	for(int j=1;j<=n;j++)
	{
		scanf("%d",&d[j]);
		if(d[j]>d[j-1])
			ans+=d[j]-d[j-1]; 
	}
	printf("%d",ans);

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值