【练习】【贪心】力扣45. 跳跃游戏 II

题目

  1. 跳跃游戏 II
    给定一个长度为 n 的 0 索引整数数组 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

来源:力扣45. 跳跃游戏 II


思路(注意事项)

维护一个最远距离和当前跳跃的边界,搞清楚这个点此题很简单。


纯代码

c 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int n = nums.size(), ans = 0, last = 0, end = 0;
        for (int i = 0; i < n - 1; i ++){
            last = max (last, nums[i] + i);
            if (i == end){
                ans ++;
                end = last;
            }
        }
        return ans;
    }
};

题解(加注释)

c 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        // n 表示数组的长度
        int n = nums.size();
        // ans 表示跳跃的次数
        int ans = 0;
        // last 表示当前能够到达的最远位置
        int last = 0;
        // end 表示当前跳跃的边界
        int end = 0;

        // 遍历数组中的每个位置(注意:只需要遍历到倒数第二个位置)
        for (int i = 0; i < n - 1; i++) {
            // 更新 last 为当前位置能够跳到的最远位置
            last = max(last, nums[i] + i);

            // 如果当前位置 i 到达了当前跳跃的边界
            if (i == end) {
                // 增加跳跃次数
                ans++;
                // 更新边界为 last
                end = last;
            }
        }

        // 返回跳跃次数
        return ans;
    }
};
相关推荐
格林威2 分钟前
基于轮廓特征的工件分类识别:实现无模板快速分拣的 8 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·目标跟踪·分类·数据挖掘
Jasmine_llq2 分钟前
《UVA11181 条件概率 Probability|Given》
数据结构·算法·深度优先搜索(dfs)·剪枝(可行性剪枝)·组合枚举(递归暴力枚举)·条件概率统计与归一化
老鼠只爱大米8 分钟前
LeetCode算法题详解 560:和为K的子数组
算法·leetcode·前缀和·哈希表·子数组求和·subarraysum
MM_MS10 分钟前
Halcon小案例--->路由器散热口个数(两种方法)
人工智能·算法·目标检测·计算机视觉·视觉检测·智能路由器·视觉
小杨同学4910 分钟前
C 语言实战:超市水果结算系统(深度解析与优化)
后端·算法·设计
编程之路,妙趣横生13 分钟前
C++ IO流
c++
fpcc23 分钟前
跟我学C++中级篇—std::conjunction手动实现
c++
项目題供诗26 分钟前
C语言基础(三)
c语言·c++
1***438044 分钟前
C++跨平台开发的核心挑战线程管理等基础功能
开发语言·c++
a3158238061 小时前
大语言模型应用开发技术要求
算法·大语言模型·应用开发