跳跃游戏(力扣55)

题目问是否可以跳到数组最后一个下标,有的同学可能会思考如何模拟跳跃这个操作,但这是比较困难的,很容易把自己绕进去。可以换一种思路,我们不需要知道具体是如何跳到最后一个下标的,而是找到最大的跳跃范围。如果该跳跃范围可以覆盖最后一个下标,就说明我们一定可以通过某种跳跃策略到达最后一个下标。更具体来说,不一定非要明确一次究竟跳几步,而是每次取最大的跳跃步数,这个就是可以跳跃的覆盖范围。这个范围内,别管是怎么跳的,反正一定可以跳过来。所谓的贪心也就是体现在:局部最优:每次取最大跳跃步数(取最大覆盖范围);整体最优: 最后得到整体最大覆盖范围,看是否能到终点。为了实现这个想法,代码的书写上还是有一定的技巧性。大家可以结合下面的代码及详细注释理解此题。

代码及详细注释如下:

复制代码
class Solution {
public:
    bool canJump(vector<int>& nums) {
    //数组长度为1,进行剪枝
      if(nums.size() == 1){
        return true;
      }
      int cover = 0;
      //用cover变量控制for循环的遍历范围
      //每遍历到一个元素,如果该元素的跳跃范围更大,
      //cover 就得到该元素数值(新的覆盖范围)的补充,让 i 继续移动下去。
      for(int i = 0;i <= cover;i++){
        cover = max(cover,i + nums[i]);
        if(cover >= nums.size() - 1){
            return true;
        }
      }
      return false;
    }
};
相关推荐
Allen_LVyingbo4 分钟前
《狄拉克符号法50讲》习题与解析(下)
算法·决策树·机器学习·健康医疗·量子计算
豆沙糕4 分钟前
大模型面试高频题:请详细讲解检索中的BM25算法
人工智能·算法
不才小强5 分钟前
查找算法详解:二分查找
数据结构·算法
君义_noip9 分钟前
信息学奥赛一本通 4164:【GESP2512七级】学习小组 | 洛谷 P14922 [GESP202512 七级] 学习小组
学习·算法·动态规划·gesp·信息学奥赛
MicroTech20259 分钟前
微算法科技(NASDAQ :MLGO)面向区块链的系统的高效反量子晶格盲签名技术
科技·算法·区块链
yuan1999723 分钟前
OpenCV ViBe 运动检测算法实现
人工智能·opencv·算法
人工智能培训1 小时前
如何将高层任务分解为可执行的动作序列?
大数据·人工智能·算法·机器学习·知识图谱
罗湖老棍子1 小时前
Power Strings(信息学奥赛一本通- P1457)
算法·字符串·哈希
MIngYaaa5201 小时前
The 2025 Sichuan Provincial Collegiate Programming Contest 复盘
算法
网域小星球1 小时前
C 语言从 0 入门(二十一)|typedef 类型重定义:简化复杂类型,代码更清爽
c语言·算法·类型重定义·结构体简化·函数指针简化