力扣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;
    }
}
相关推荐
IAUTOMOBILE11 分钟前
Python 流程控制与函数定义:从调试现场到工程实践
java·前端·python
hutengyi11 分钟前
PostgreSQL版本选择
java
皮皮林55117 分钟前
重磅!JetBrains 正式发布全新的 AI 开发工具,定名 AI IDE AIR
java·intellij idea
MX_935930 分钟前
SpringMVC请求参数
java·后端·spring·servlet·apache
ID_1800790547336 分钟前
小红书笔记评论 API,Python 调用示例与完整 JSON 返回参考
java·开发语言
Fuxiao___39 分钟前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
lifewange40 分钟前
java连接Mysql数据库
java·数据库·mysql
Mr_Xuhhh1 小时前
LeetCode hot 100(C++版本)(上)
c++·leetcode·哈希算法
漫随流水1 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
云原生指北1 小时前
命令行四件套:fd-rg-fzf-bat
java·大数据·elasticsearch