力扣45.跳跃游戏II

复制代码
class Solution {
    public int jump(int[] nums) {
        // 初始化步数为0
        int step = 0;
        // 初始化当前能到达的最远位置为0
        int maxp = 0;
        // 初始化下一个跳跃的边界位置为0
        int end = 0;
        // 遍历数组,除了最后一个元素
        for(int i=0;i<nums.length-1;i++) {
            // 如果当前位置加上当前位置的值大于最远位置,更新最远位置
            if(nums[i] + i > maxp)
                maxp = nums[i]+i;
            // 如果当前位置等于下一个跳跃的边界位置
            if(end == i) {
                // 更新下一个跳跃的边界位置为最远位置
                end = maxp;
                // 步数加1
                step++;
            }
        }
        // 返回总步数
        return step;
    }
}
相关推荐
q***46521 小时前
在2023idea中如何创建SpringBoot
java·spring boot·后端
hygge9991 小时前
Spring Boot + MyBatis 整合与 MyBatis 原理全解析
java·开发语言·经验分享·spring boot·后端·mybatis
q***25211 小时前
Spring Boot接收参数的19种方式
java·spring boot·后端
WX-bisheyuange1 小时前
基于Spring Boot的民谣网站的设计与实现
java·spring boot·后端
q***14641 小时前
Spring Boot文件上传
java·spring boot·后端
Run_Teenage2 小时前
C++:智能指针的使用及其原理
开发语言·c++·算法
WX-bisheyuange3 小时前
基于Spring Boot的民宿预定系统的设计与实现
java·spring boot·后端·毕业设计
码界奇点4 小时前
Java设计模式精讲从基础到实战的常见模式解析
java·开发语言·设计模式·java-ee·软件工程
mit6.8244 小时前
二维差分+前缀和
算法
民乐团扒谱机4 小时前
自然的算法:从生物进化到智能优化 —— 遗传算法的诗意与硬核“
算法