当前位置: 首页 > article >正文

跳跃游戏(力扣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;
    }
};


 


http://www.kler.cn/a/556848.html

相关文章:

  • Selenium实战案例1:论文pdf自动下载
  • 城电科技|可展开光伏花 绽放绿色 点亮未来
  • JavaScript 中,数据类型 有哪些?(复习/面试)
  • JVM系列--虚拟机类加载机制
  • TSMaster【第四篇:目击之术——总线测量窗口精解】
  • MATLAB拟合算法:如何使用 MATLAB 进行多组数据的高斯拟合分析
  • 【Kubernets】Kubernets资源类型Deployment详细介绍
  • 图数据库Neo4j面试内容整理-深度优先搜索(DFS)和广度优先搜索(BFS)
  • C语言03
  • 可编辑112页PPT | DeepSeek行业应用实践报告
  • 【TOT】Tree-of-Thought Prompting
  • day16_推荐系统和总结
  • ARM64 Trust Firmware [四]
  • 开启开源新时代:DeepSeek引领人工智能技术开放化
  • 科普:你的笔记本电脑中有三个IP:127.0.0.1、无线网 IP 和局域网 IP;两个域名:localhost和host.docker.internal
  • 电力通信物联网应用,国密网关守护电力数据安全
  • Java 表达式、语句和块
  • nginx配置:nginx.conf配置文件
  • spring中事务为什么会回滚?什么原理?
  • Vue 和 React 响应式的区别