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;
    }
相关推荐
favour_you___几秒前
算法练习2026/4/13
算法·深度优先
2401_892070981 分钟前
八大排序算法
数据结构·c++·排序算法
吃着火锅x唱着歌4 分钟前
LeetCode 1963 使字符串平衡的最小交换次数
算法·leetcode·职场和发展
会编程的土豆10 分钟前
【数据结构与算法】哈希表
数据结构·散列表
无敌昊哥战神10 分钟前
【算法与数据结构】深入浅出回溯算法:理论基础与核心模板(C/C++与Python三语解析)
c语言·数据结构·c++·笔记·python·算法
zore_c11 分钟前
【C++】基础语法(命名空间、引用、缺省以及输入输出)
c语言·开发语言·数据结构·c++·经验分享·笔记
輕華13 分钟前
OpenCV三大传统人脸识别算法:EigenFace、FisherFace与LBPH实战
人工智能·opencv·算法
akarinnnn14 分钟前
【DAY16】字符函数和字符串函数
c语言·数据结构·算法
_日拱一卒20 分钟前
LeetCode:螺旋矩阵
算法·leetcode·矩阵
Tairitsu_H24 分钟前
C语言:排序(二)
c语言·开发语言·算法