leetcode10(跳跃游戏 II)

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

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

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

返回到达 n - 1 的最小跳跃次数。测试用例保证可以到达 n - 1

思路:

计算最少跳跃次数:

采用贪心的思想

从0开始,向外辐射最远能到达的位置,设为边界

在目前能到达的范围内,依次访问,更新最远能到达的位置,直到访问到设置的边界

此时,需要走一步,同时更新边界为现在所能到达的最远位置

再进行第二步范围内的遍历,

直到到达或超过最终位置,表明不需要再走一步,输出结果

java 复制代码
    public int jump(int[] nums) {
        int end=0;
        int max=0;
        int k=0;
        for(int i=0;i<nums.length-1;i++){
            max=Math.max(max,i+nums[i]);
            if(i==end){
                k++;
            }
        }
        return k;
    }
相关推荐
点云SLAM10 分钟前
四元数 (Quaternion)微分-四元数导数的矩阵表示推导(8)
线性代数·算法·计算机视觉·矩阵·机器人·slam·四元数
潼心1412o19 分钟前
数据结构(长期更新)第8讲:队列
数据结构
kyle~44 分钟前
算法---贪心算法(Greedy Algorithm)
算法·贪心算法
fashion 道格1 小时前
C 语言数组拼接:从基础实现到细节优化
算法
头发还没掉光光1 小时前
Linux多线程之自旋锁与读写锁
linux·运维·算法
fashion 道格1 小时前
C 语言希尔排序:原理、实现与性能深度解析
数据结构·算法·排序算法
如意猴1 小时前
实现链式结构二叉树--递归中的暴力美学(第13讲)
数据结构
初夏睡觉1 小时前
P1048 [NOIP 2005 普及组] 采药
数据结构·c++·算法
小欣加油1 小时前
leetcode 1513 仅含1的子串数
c++·算法·leetcode·职场和发展
树在风中摇曳2 小时前
【C语言预处理器全解析】宏、条件编译、字符串化、拼接
c语言·算法