【贪心算法】Leetcode 55. 跳跃游戏 45. 跳跃游戏 I

【贪心算法】Leetcode 55. 跳跃游戏 45. 跳跃游戏 II

Leetcode 55. 跳跃游戏

---------------🎈🎈55. 跳跃游戏 题目链接🎈🎈-------------------
在这里插入图片描述

解法1 贪心

在这里插入图片描述

关键点在于:不用拘泥于每次究竟跳几步,而是看覆盖范围,覆盖范围内一定是可以跳过来的,不用管是怎么跳的。
⭐️每次移动取最大跳跃步数(得到最大的覆盖范围),每移动一个单位,就更新最大覆盖范围coverRange。

class Solution {
    public boolean canJump(int[] nums) {
        // 遍历数组,nums[i]代表当前可以覆盖到的最大范围coverRange,
        // 在循环中不断的修改这个coverRange
        // 之后在这个范围中遍历,最终看能否覆盖到最后一个下标
        if(nums.length == 1) return true;
        int coverRange = 0;
        for(int i = 0; i <= coverRange; i++){
            coverRange = Math.max(coverRange,nums[i]+i); //动态更新coverRange
            if(coverRange >= nums.length-1) return true;
        }
    
        return false;
    }
}          

Leetcode 45. 跳跃游戏I

在这里插入图片描述

解法 贪心

为了以最小步数跳跃到最后一节点,意味着:
如果当前的覆盖范围coverrange不包含最后一个节点,那么就遍历到当前覆盖范围的最后一个元素nums[coverrange],期间记录每个节点的覆盖范围nums[i]+i,取最大的存入max
在遍历完当前覆盖范围的最后一个元素后,更新覆盖范围coverrange为max,跳跃次数+1
如果当前覆盖范围包含了最后一个节点,跳跃次数+1,结束

class Solution {
    public int jump(int[] nums) {
        if(nums.length == 1) return 0;
        int coverrange =nums[0];
        int max = nums[0];
        int result = 0;
      
        for(int i = 0; i<=coverrange;i++){
            
            if(coverrange>=nums.length-1){  // 如果覆盖范围coverrange大于了目标,那么代表跳跃次数+1后可以到达,break
                result++;
                break;
            }

            if(nums[i]+i>max){ // 如果当前遍历的nums[i]+i>max,那么就更新目前coverrange中的最大范围max
                max=nums[i]+i;
            }

            if(i==coverrange){ // 如果当前遍历到覆盖范围coverrange的最后一个,那么就更新覆盖范围为max,之后跳跃次数+1
                coverrange=max;
                result++;
            }
        }
        return result;
    }
}

相关推荐

  1. 贪心算法Leetcode 55. 跳跃游戏【中等】

    2024-03-19 16:22:01       9 阅读
  2. 贪心LeetCode-55. 跳跃游戏

    2024-03-19 16:22:01       40 阅读
  3. leetcode跳跃游戏贪心算法

    2024-03-19 16:22:01       37 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-19 16:22:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-19 16:22:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-19 16:22:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-19 16:22:01       20 阅读

热门阅读

  1. 大模型-Prompt

    2024-03-19 16:22:01       20 阅读
  2. QB web 自定义页面

    2024-03-19 16:22:01       26 阅读
  3. (二)pulsar安装在独立的docker中,python测试

    2024-03-19 16:22:01       21 阅读
  4. python使用excel需要用到哪些模块?

    2024-03-19 16:22:01       23 阅读
  5. 常用的vim和linux命令

    2024-03-19 16:22:01       20 阅读
  6. 代码随想录Day24

    2024-03-19 16:22:01       21 阅读
  7. ElasticSearch简介及常见用法

    2024-03-19 16:22:01       17 阅读
  8. C++ QT串口通信(1)-串口模块QtSerialPort详解

    2024-03-19 16:22:01       22 阅读
  9. 数据库表的查询

    2024-03-19 16:22:01       20 阅读
  10. 每天学习一个Linux命令之rm

    2024-03-19 16:22:01       24 阅读