力扣45. 跳跃游戏 II

给定一个长度为 n0 索引 整数数组 nums。初始位置为 nums[0]
每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:

  • 0 <= j <= nums[i]
  • i + j < n

返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]


示例 1:

复制代码
输入: nums = [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。

示例 2:

复制代码
输入: nums = [2,3,0,1,4]
输出: 2

提示:

  • 1 <= nums.length <= 104
  • 0 <= nums[i] <= 1000
  • 题目保证可以到达 nums[n-1]

代码:

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int maxmost = 0, len = nums.size(), step = 0, end = 0;

        for(int i = 0; i < len-1; i++){

            if(i <= maxmost){
                maxmost = max(i+nums[i], maxmost);
                if(i == end){
                    end = maxmost;
                    step++;
                }
            }
        }

        return step;
    }
};

解题思路:

(1)使用贪心思想。

(2)每次跳到下一次能跳到最远距离的下标。

(3)使用 end 来限制当前步数能跳到的最远距离。

相关推荐
tankeven3 分钟前
HJ94 记票统计
c++·算法
逆境不可逃7 分钟前
LeetCode 热题 100 之 76.最小覆盖子串
java·算法·leetcode·职场和发展·滑动窗口
I_LPL13 分钟前
day35 代码随想录算法训练营 动态规划专题3
java·算法·动态规划·hot100·求职面试
DeepModel16 分钟前
【回归算法】多项式回归详解
算法·回归
踩坑记录24 分钟前
leetcode hot100 78. 子集 递归回溯 medium 位运算法
leetcode
Frostnova丶34 分钟前
LeetCode 761. 特殊的二进制字符串
算法·leetcode
不吃橘子的橘猫1 小时前
《集成电路设计》复习资料3(电路模拟与SPICE)
学习·算法·集成电路·仿真·半导体
m0_531237171 小时前
C语言-函数递归
算法
mjhcsp1 小时前
C++Z 函数超详细解析
c++·算法·z 函数
再难也得平1 小时前
[LeetCode刷题]49.字母异位词分组(通俗易懂的java题解)
java·开发语言·leetcode