跳跃游戏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。
最后输出最少的跳跃次数。
代码:
#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;
}这一题我使用的是贪心的算法,之前跳跃过程中所可能经过的数组求他们所能组成最大的数字的和(就代表跳的跨度大,相对应的就是跳的次数就会少)。
数组中的每个元素代表你在那个位置能够跳跃的最大长度。
你的目标是到达最后一个下标,并且使用最少的跳跃次数。
例如:
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;
}这一题我使用的是贪心的算法,之前跳跃过程中所可能经过的数组求他们所能组成最大的数字的和(就代表跳的跨度大,相对应的就是跳的次数就会少)。
相关文章推荐
- leet55. 跳跃游戏
- Android游戏开发十日通(4)-行走,跳跃,碰撞检测
- Unity3D ARPG游戏开发《最初的幻想》之第一张地图与跳跃的改善详解
- 计蒜客--第18题:跳跃游戏
- 算法爱好者——算法题:跳跃游戏 ? 待解决
- 3D游戏中NPC的跳跃技能实现、原理解析、视频演示及代码演示 - LuoYing RPG
- [Lintcode]Jump Game跳跃游戏
- 计蒜客刷题之旅 之 跳跃游戏二
- Java实现-跳跃游戏2
- [Leetcode] jump game ii 跳跃游戏
- lintcode-117-跳跃游戏 II
- 计蒜客 难题题库 020 跳跃游戏二
- 跳跃游戏(一,二)
- 跳跃游戏一(动态规划)
- Android游戏开发十日通(4)-行走,跳跃,碰撞检测
- 计蒜客————跳跃游戏二
- [LeetCode] Jump Game II 跳跃游戏之二
- LeetCode OJ:Jump Game(跳跃游戏)
- 计蒜客--第20题:跳跃游戏二
- 【leetcode】Jump Game I, II 跳跃游戏一和二