力扣HOT100之贪心算法:45. 跳跃游戏 II

这道题刷代码随想录的时候也刷过,本来以为有了上一题55.跳跃游戏的基础,这道题会好做一点,但是依旧想不出来思路,回去看了下自己当时写的博客,没想到今天的感受和当时的感受都一模一样。。。What can I say?看了下代码随想录的视频灵神的题解,终于把这个问题彻底弄清楚了。

由于这道题保证一定能跳到终点,所以我们只需要考虑如何花最少的次数跳到终点,这里我们定义resultcurrentnext三个变量,result用于记录最小跳跃次数,current代表本次跳跃后所能达到的覆盖范围的最远边界,next代表下一次跳跃所能达到的最远覆盖范围,然后用一个for循环来遍历nums的元素,当我们遍历到current处,则说明我们已经达到了当前覆盖范围的边界,我们需要先判断是否已经到达数组的边界,如果还没到达,则当前是已经到达覆盖范围边界但是尚未达到数组的边界 。我们必须跳跃一次,并将current移动到下一次跳跃后的覆盖范围的边界,即current = next;result++;;当进入下一轮for循环时,则i进入下次跳跃的覆盖范围,我们再不断地更新下下次跳跃的最远覆盖范围,即next = max(next, i + nums[i]);。如果i已经到达了数组边界,则无需进行下一次跳跃,直接退出循环即可。

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int current = 0;  //记录当前所在的位置
        int result = 0;   //记录最小次数
        int next = 0;
        for(int i = 0; i < nums.size(); i++){
            next = max(next, i + nums[i]);   //更新最大覆盖范围
            if(i == current){  
                //已经到达覆盖范围边界,需要进行一次跳跃,直接跳到下一个最大覆盖范围的边界
                if(i != nums.size() - 1){  //已经到达覆盖范围边界但是尚未达到数组的边界
                    result++;
                    current = next;
                }
            }
        }
        return result;
    }
};
相关推荐
阿Y加油吧13 分钟前
两道字符串 DP 模板题复盘:最长公共子序列 & 编辑距离
leetcode
我爱cope24 分钟前
【力扣hot100:76. 最小覆盖子串】
算法·leetcode·职场和发展
津津有味道41 分钟前
一键写入启动游戏NDEF复合记录NFC标签vb6源码
游戏·标签·nfc·ndef·复合记录
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.05.20 题目:2657. 找到前缀公共数组
笔记·算法·leetcode
游乐码1 小时前
Unity基础(四)向量相关
游戏·unity·游戏引擎
吃着火锅x唱着歌2 小时前
LeetCode 962.最大宽度坡
算法·leetcode·职场和发展
凌波粒2 小时前
LeetCode--257. 二叉树的所有路径(二叉树)
算法·leetcode·职场和发展
阿Y加油吧3 小时前
两道数组算法题复盘:多数元素 & 颜色分类
算法·leetcode·职场和发展
阿阳微客3 小时前
网易Buff游戏搬砖,长期可做!
笔记·学习·游戏
Kurisu5753 小时前
探灵直播2026最新官方正版免费下载 一键转存 永久更新 (看到速转存 资源随时走丢)
游戏·游戏引擎·游戏程序·动画·关卡设计