您的位置:首页 > 其它

跳跃游戏2--计蒜课

2018-02-06 17:44 162 查看
给定一个非负整数数组,假定你的初始位置为数组第一个下标。

数组中的每个元素代表你在那个位置能够跳跃的最大长度。

你的目标是到达最后一个下标,并且使用最少的跳跃次数。

例如:

A
= [2,3,1,1,4]A=[2,3,1,1,4],到达最后一个下标的最少跳跃次数为 22。(先跳跃 11 步,从下标 00 到 11,然后跳跃 33 步,到达最后一个下标。一共两次)


输入格式

第一行输入一个正整数 n(1
\le n \le 100)n(1≤n≤100) ,接下来的一行,输入 nn 个整数,表示数组 AA。


输出格式

最后输出最少的跳跃次数。


样例输入

5
3 1 1 1 1



样例输出

2


代码:

#include<iostream>
using namespace std;
int count=0,n;
int tiao(int i,int a[])
{
int k,j=0,l,max=0;
if(i>=n-1)
{
return 0;
}
k=a[i];
count++;
if(i+k>=n-1)
return 0;
for(l=i+1;l<=i+k;l++)
{
if(max<=l+a[l])
{
j=l;
max=l+a[l];
}
}
tiao(j,a);
}
int main()
{
int a[110];
cin>>n;
for(int i=0;i<n;i++)
{
cin>>a[i];
}
int j=a[0];
tiao(0,a);
cout<<count<<endl;
}这一题我使用的是贪心的算法,之前跳跃过程中所可能经过的数组求他们所能组成最大的数字的和(就代表跳的跨度大,相对应的就是跳的次数就会少)。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: