> 文档中心 > 蓝桥杯每日一练——跳跃游戏二

蓝桥杯每日一练——跳跃游戏二

跳跃游戏二icon-default.png?t=M276https://leetcode-cn.com/problems/jump-game-ii/

题目描述:

给你一个非负整数数组 nums ,你最初位于数组的第一个位置

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

假设你总是可以到达数组的最后一个位置。

解题方法:贪心算法  

注意每次能达到的最大位置并不一定是最优解,这里与贪心算法还存在一定的区别,不完全是。 

class Solution {public:    int jump(vector& nums) { int max_far = 0; int n = nums.size(); int step = 0; int end = 0; for(int i = 0; i< n - 1; i++){     max_far = max(max_far, i + nums[i]);     if( end == i ){  end = max_far;  step++;     } } return step;    }};