A-道路铺设 题解(2018NOIP提高组复赛)

道路铺设

https://ac.nowcoder.com/acm/contest/294/A

洛谷题库传送门

牛客题库传送门

题目描述

春春是一名道路工程师,负责铺设一条长度为n的道路。

铺设道路的主要工作是填平下陷的地表。整段道路可以看作是n块首尾相连的区域,一开始,第i块区域下陷的深度为di。

春春每天可以选择一段连续区间[L,R],填充这段区间中的每块区域,让其下陷深度减少1。在选择区间时,需要保证,区间内的每块区域在填充前下陷深度均不为0。

春春希望你能帮他设计一种方案,可以在最短的时间内将整段道路的下陷深度都变为0。


输入描述

输入包含两行,第一行包含一个整数n,表示道路的长度。第二行包含n个整数,相邻两个数间用一个空格隔开,第i个整数为 d i。


输出描述

输出文件仅包含一个整数,即最少需要多少天才能完成任务。

示例1

输入

6

4 3 2 5 3 5

输出

9

说明

一种可行的最佳方案是,依次选择:
[1,6]、[1,6]、[1,2]、[1,1]、[4,6]、[4,4]、[4,4]、[6,6]、[6,6]。

备注

对于30%的数据,1 ≤ n ≤ 10;

对于70%的数据,1 ≤ n ≤ 1000;

对于100%的数据,1 ≤ n ≤ 100000,0 ≤ di ≤ 10000 。


题解

首先来分析示例数据
1
这是按照示例数据画出来的示意图,
那么填过之后就变成了这样2
这样太麻烦了,仔细观察图2,有没有发现一个规律,

其实我们可以这样子
先把第1列的道路先填起来,记到天数sum中,然后将第一列下陷的深度后面的深度相比较,若后面的有一个小于它,则整条道路上都被填满了最浅的那个坑的深度的土,如图。3

然后我们通过使用for循环遍历整条道路,在前一步的基础上,增加天数sum,如图5

图片颜色标记错了,第5列的5也是红色

继续
6

图片颜色标记错了,第5列的5也是红色

最后
7

我们的算法应该这样实现

123]

至此这道题就算完成了!


最后贴上完整代码

#include<bits/stdc++.h>
using namespace std;
int main(112)    //FangZuoBi
{
    //freopen ("road.in","r",stdin);
    //freopen ("road.out","w",stdout);
    int n,sum=0,l=0;
    scanf("%d",&n);
    for(int i=1;i<=n;++i)
        {
            int a;
            scanf("%d",&a);
            if(a>l)
                sum+=(a-l);
            l=a;
        }
        printf("%d\n",sum);
    return 0;
}
全部评论
qwq
点赞 回复 分享
发布于 2019-09-09 22:38

相关推荐

不愿透露姓名的神秘牛友
09-30 19:49
起名星人:蛮离谱的,直接要求转投销售
投递汇川技术等公司10个岗位
点赞 评论 收藏
分享
10-11 15:42
皖西学院 Java
青鱼LINK:我硕士,也是java0面试,吾道不孤
点赞 评论 收藏
分享
4 收藏 评论
分享
牛客网
牛客企业服务