试题 算法训练 积木大赛
创始人
2024-05-31 18:24:12

问题描述

  THU幼儿园举办了一年一度的“积木大赛”。今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi。
  在搭建开始之前,没有任何积木(可以看成n块高度为0的积木)。接下来每次操作,小朋友们可以选择一段连续区间[L, R],然后将第L块到第R块之间(含第L块和第R块)所有积木的高度分别增加1。
  kAc是个聪明的小朋友,他很快想出了建造大厦的最佳策略,使得建造所需的操作次数最少。但他不是一个勤于动手的孩子,所以想请你帮忙实现这个策略,并求出最少的操作次数。

输入格式

  输入包含两行,第一行包含一个整数n,表示大厦的宽度。
  第二行包含n个整数,第i个整数为hi。

输出格式

  仅一行,即建造所需的最少操作数。

样例输入

5
2 3 4 1 2

样例输出

5

数据规模和约定

  1<=n<=100000
  0<=hi<=10000

#include
using namespace std;int main() {int n;int sum = 0;int different = 0;cin >> n;for (int i = 0; i < n; i ++) {int temp;cin >> temp;if (temp > different) {sum = sum + temp - different;different = temp;} else {different = temp;}}cout << sum;return 0;
}

总结:

差异点就是在比上个数小的那个数

如果比上个数大,那么就一直更新sum

如果比上个数小,那么这里开始断点

直到遇到比上个数大的数字,才继续开始计数

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...