力扣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;
    }
}
相关推荐
txinyu的博客几秒前
Reactor 模型全解析
java·linux·开发语言·c++
IMPYLH几秒前
Lua 的 Package 模块
java·开发语言·笔记·后端·junit·游戏引擎·lua
sunnyday04261 分钟前
API安全防护:签名验证与数据加密最佳实践
java·spring boot·后端·安全
间彧2 分钟前
java类的生命周期及注意事项
java
DuHz4 分钟前
自动驾驶雷达干扰缓解:探索主动策略论文精读
论文阅读·人工智能·算法·机器学习·自动驾驶·汽车·信号处理
会飞的小新4 分钟前
Java 应用程序已被安全阻止 —— 原因分析与解决方案
java·安全
漫随流水6 分钟前
leetcode算法(257.二叉树的所有路径)
数据结构·算法·leetcode·二叉树
Geoking.8 分钟前
【设计模式】责任链模式(Chain of Responsibility)详解
java·设计模式·责任链模式
liu****9 分钟前
神经网络基础
人工智能·深度学习·神经网络·算法·数据挖掘·回归
有一个好名字9 分钟前
力扣-二叉树的最大深度
算法·leetcode·深度优先