力扣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;
    }
}
相关推荐
牛三金4 分钟前
匿踪查询沿革-Private Information Retrieval(PIR)
算法·安全
德育处主任4 分钟前
『NAS』在群晖部署一个文件加密工具-hat.sh
前端·算法·docker
刀法如飞4 分钟前
一款开箱即用的Spring Boot 4 DDD工程脚手架
java·后端·架构
一嘴一个橘子8 分钟前
spring-aop 的 基础使用 -3 - 切点表达式 的提取、复用
java
星辞树8 分钟前
从 L1/L2 到 Dropout:深度解析正则化,为何推荐系统“只能练一次”?
算法
Re_zero11 分钟前
Java新手避坑:为什么我劝你放弃 scanner.nextInt()?
java
玖剹12 分钟前
队列+宽搜(bfs)
数据结构·c++·算法·leetcode·宽度优先
mit6.82434 分钟前
01bfs|前缀和的前缀和
算法
wen__xvn34 分钟前
代码随想录算法训练营DAY11第五章 栈与队列part02
算法