问题描述
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
如果比上个数小,那么这里开始断点
直到遇到比上个数大的数字,才继续开始计数