贪心算法---跳跃游戏(2)

题目:

给定一个长度为 n0 索引 整数数组 nums。初始位置为 nums[0]

每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:

  • 0 <= j <= nums[i]
  • i + j < n

返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]

思路:

从覆盖范围出发,不管怎么跳,覆盖范围内一定可以跳到,以最小步数增加覆盖范围,覆盖范围一旦覆盖了终点得到的就是最小步数。

统计两个覆盖范围,当前这一步的最大覆盖范围和下一步最大覆盖范围。如果移动下标到了当前这一步的最大覆盖最远距离,还没有到达终点的话,那么就必须再走一步来增加覆盖范围,直到覆盖范围覆盖了终点。

有一个特殊情况需要考虑,当移动下标达到了当前覆盖的最远距离下标时,如果当前覆盖最远距离下表不是集合终点,步数加一,还要继续走;如果当前覆盖最远距离下标是集合终点,部署不用加一,因为不能再往后走了。

代码:

java 复制代码
    public int jump(int[] nums) {
        if(nums.length==1) return 0;//数组只有一个元素,不用跳跃
        int curDistance=0;//当前覆盖的最远距离下标
        int ans=0;//记录走的步数
        int nextDistance=0;//下一步覆盖最远距离下标
        for(int i=0;i<nums.length;i++){
            nextDistance=Math.max(nums[i]+i,nextDistance);//更新下一步覆盖最远距离下标
            if(i==curDistance){//遇到当前覆盖最远距离下标
                ans++;//需要走下一步
                curDistance=nextDistance;//更新当前覆盖的最远距离下标
               if(nextDistance>=nums.length-1) break;//当前覆盖范围包含终点,直接结束
            }
        }
        return ans;
    }
相关推荐
先做个垃圾出来………4 分钟前
1. 两数之和
算法·leetcode·职场和发展
神器阿龙30 分钟前
排序算法-冒泡排序
数据结构·算法·排序算法
C++ 老炮儿的技术栈1 小时前
在vscode 如何运行a.nut 程序(Squirrel语言)
c语言·开发语言·c++·ide·vscode·算法·编辑器
HKUST_ZJH1 小时前
交互 Codeforces Round 1040 Interactive RBS
c++·算法·交互
九章数学体系1 小时前
九章数学体系:打破“吃苦悖论”,重构学习真谛
数据结构·学习·算法·数学建模·拓扑学
一川月白7091 小时前
数据结构---概念、数据与数据之间的关系(逻辑结构、物理结构)、基本功能、数据结构内容、单向链表(该奶奶、对象、应用)
c语言·数据结构·算法·哈希算法·单向链表·数据关系
展信佳_daydayup2 小时前
8-1 图像增广
算法
zl_vslam2 小时前
SLAM中的非线性优化-2D图优化之零空间实战(十六)
人工智能·算法·机器学习·计算机视觉·slam se2 非线性优化
闪电麦坤952 小时前
数据结构:链表(Linked List)
数据结构·链表
qystca2 小时前
MC0351区间询问和
算法