链接:登录—专业IT笔试面试备考平台_牛客网
来源:牛客网
题目描述
一只南美洲亚马孙河流域热带雨林中的蝴蝶,偶尔扇动几下翅膀,可
以在两周以后引起美国德克萨斯州的一场龙卷风。――蝴蝶效应
由于这个理论的存在,大多数人认为将未来的事物送回过去将会引发
严重的时间悖论,但事实上还存在另外一套理论。
自然会对这类不和谐的蝴蝶效应做出调整,具体地来说就是触发一些
小概率的恶性事件来抹杀穿越者来消除其对未来的影响。
虽然听上去很荒诞,但Alicebell决定去验证这一假说,她将按1 ∼ n的
顺序依次到访过去的n个时间点。
这n个时间点各有一个能源参数A𝑖,即到达这个时间点时,身上必须
保证有A𝑖单位的能量,那之后将会消耗掉一单位的能量。
Alicebell想知道依次到访这n个时间点,最初需要携带至少多少能量。
输入描述:
第一行,一个正整数n。
第二行,n个正整数A𝑖。
输出描述:
一行,一个正整数,最初需要携带能量下限。
示例1
输入
复制5 1 2 5 4 2
5 1 2 5 4 2
输出
复制7
7
思路:身上必须保证有A𝑖单位的能量,那之后将会消耗掉一单位的能量。这句话非常重要,说明了经过一个点能量要减一,所花费的能量为a[i]+i.从起点到第一个点的时候,能量减一,到最后一个点的时候,找能量花费最大的即可。
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
cin>>n;
int a[n];
int maxn=0;
for(int i=0;i<n;i++)
{
cin>>a[i];
maxn = max(maxn , a[i] + i ) ;
}
cout<<maxn<<endl;
return 0;
}