【LeetCode热题100】-- 45.跳跃游戏II

45.跳跃游戏II

方法:贪心

在具体的实现中,维护当前能够到达的最大下标的位置,记为边界。从左到右遍历数组,到达边界时,更新边界并将跳跃次数加一

在遍历数组时,不访问最后一个元素,因为在访问最后一个元素之前,我们的边界一定大于等于最后一个位置,否则就无法跳到最后一个位置了。

java 复制代码
class Solution {
    public int jump(int[] nums) {
        int n = nums.length;
        int maxPosition = 0,steps = 0,end = 0;
        for(int i = 0;i < n - 1;i++){
            maxPosition = Math.max(maxPosition, i + nums[i]);  //下次最远能跳多远
            if( i == end ){
                end = maxPosition;  //更新下一次跳的位置
                steps++;  //本次跳跃的所有位置都检查过了,跳跃一次
            }
        }
        return steps;
    }
}
相关推荐
艺术电影节12 分钟前
祝贺电影《撤离》《悼念词》《水草长生》 荣获亚洲艺术电影节提名
算法·推荐算法·电视
MATLAB代码顾问19 分钟前
改进鲸鱼优化算法(IWOA)求解柔性作业车间调度问题(FJSP)——附MATLAB代码
开发语言·算法·matlab
量子-Alex35 分钟前
【大模型】EvoLM论文LLM训练各个阶段效果
人工智能·算法·机器学习
Hello world.Joey1 小时前
OSTrack
人工智能·算法·目标检测·目标跟踪
WL_Aurora1 小时前
Python 算法基础篇之堆和优先队列
python·算法
努力努力再努力wz1 小时前
【MySQL进阶系列】一文打通事务机制:从锁、Undo Log 到 MVCC 与隔离级别
c语言·数据结构·数据库·c++·mysql·算法·github
薇茗1 小时前
【初阶数据结构】 左右逢源的分支诗律 二叉树1
c语言·数据结构·算法
澈2071 小时前
C++ string全面解析:从入门到精通
数据结构·c++·算法
码农的神经元1 小时前
拆解 SDGT 算法:图神经网络 + Transformer 如何做短期电力负荷预测
神经网络·算法·transformer
Irissgwe1 小时前
算法之滑动窗口
数据结构·算法