_55跳跃游戏 && _45跳跃游戏II

原题链接:

_55跳跃游戏 && _45跳跃游戏II

https://leetcode.cn/problems/jump-game-ii/description/

完成情况:

在这里插入图片描述

解题思路:

_55跳跃游戏

 /**
     * 给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
     * 判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。
     * @param nums
     * @return
     */

_45跳跃游戏II

    /**
     * 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:
     * 返回到达 nums[n - 1] 的最小跳跃次数。
     *
     * @param nums
     * @return
     */

参考代码:

_55跳跃游戏

package 代码随想录.贪心算法;

public class _55跳跃游戏 {
   
    /**
     * 给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
     * 判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。
     * @param nums
     * @return
     */
    public boolean canJump(int[] nums) {
   
        if (nums.length == 0 || nums.length == 1) {
   
            return true;
        }
        //覆盖范围, 初始覆盖范围应该是0,因为下面的迭代是从下标0开始的
        int coverRange = 0;
        //在覆盖范围内更新最大的覆盖范围
        for (int i=0;i<=coverRange;i++){
   
            coverRange = Math.max(coverRange,i+nums[i]);    //i+num[i]表示能探索到的最远的位置
            //coverRange则是老老实实的每一个都去探索,同时在扩展能够探索到的最远的位置
            if (coverRange == nums.length - 1){
   
                return true;
            }
        }
        return false;
    }
}

_45跳跃游戏II_从覆盖范围角度考虑

package 代码随想录.贪心算法;

public class _45跳跃游戏II_从覆盖范围角度考虑 {
   
    /**
     * 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:
     * 返回到达 nums[n - 1] 的最小跳跃次数。
     *
     * @param nums
     * @return
     */
    public int jump(int[] nums) {
   
        //每次去寻找当前能跳到范围内的下一次能跳的最远的位置
        if (nums == null || nums.length == 0 || nums.length == 1) {
   
            return 0;
        }
        //记录跳跃次数,即为答案
        int result_jumpTime = 0;
        //记录当前位置所能覆盖的最大区域
        int curCoverRange = 0;
        //记录当前节点所有能选择的位置,所产生的最远位置
        int maxCoverRange = 0;
        for (int i = 0;i< nums.length;i++){
   
            //在可覆盖区域内更新最大的覆盖区域
            //不考虑我到底跳在了哪个位置,只考虑我能跳到多远!!!
            maxCoverRange = Math.max(maxCoverRange,i+nums[i]);
            //说明当前一步,再跳一步就到达了末尾
            if (maxCoverRange >= nums.length - 1){
   
                result_jumpTime++;
                break;
            }
            //走到当前覆盖的最大区域时,更新下一步可达的最大区域
            if (i==curCoverRange){
   
                curCoverRange = maxCoverRange;
                result_jumpTime++;
            }
        }
        return result_jumpTime;
    }
}

_45跳跃游戏II

package 代码随想录.贪心算法;

public class _45跳跃游戏II {
   
    public int jump(int[] nums) {
   
        int result = 0;
        // 当前覆盖的最远距离下标
        int end = 0;
        // 下一步覆盖的最远距离下标
        int temp = 0;
        for (int i = 0; i <= end && end < nums.length - 1; i++) {
   
            temp = Math.max(temp, nums[i] + i);
            // 可达位置的改变次数就是跳跃次数
            if (i == end) {
   
                end = temp;
                result++;
            }
        }
        return result;
    }
}

错误经验吸取

 //不考虑我到底跳在了哪个位置,只考虑我能跳到多远!!!

相关推荐

  1. 45. 跳跃游戏 II

    2023-12-19 18:56:03       36 阅读
  2. 45. 跳跃游戏 II

    2023-12-19 18:56:03       28 阅读
  3. 45. 跳跃游戏 II

    2023-12-19 18:56:03       30 阅读
  4. 45. 跳跃游戏 II

    2023-12-19 18:56:03       18 阅读
  5. 跳跃游戏 + 45. 跳跃游戏 II

    2023-12-19 18:56:03       45 阅读

最近更新

  1. TCP协议是安全的吗?

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

    2023-12-19 18:56:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-19 18:56:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-19 18:56:03       20 阅读

热门阅读

  1. 硬件编程语言

    2023-12-19 18:56:03       45 阅读
  2. json-server详解

    2023-12-19 18:56:03       40 阅读
  3. 解决matplotlib中文显示乱码

    2023-12-19 18:56:03       45 阅读
  4. 面试题,手写soft_nms

    2023-12-19 18:56:03       44 阅读
  5. 音频筑基:瞬态、基音、偏噪信号类型分析

    2023-12-19 18:56:03       37 阅读
  6. 2312d,D语言单元测试等

    2023-12-19 18:56:03       51 阅读
  7. == 和 equals 的区别

    2023-12-19 18:56:03       37 阅读
  8. Postman中raw是什么

    2023-12-19 18:56:03       34 阅读
  9. ansible

    ansible

    2023-12-19 18:56:03      33 阅读
  10. Spring 框架中都用到了哪些设计模式?

    2023-12-19 18:56:03       50 阅读