【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;
    }
}
相关推荐
共享家952712 分钟前
数独系列算法
算法·深度优先
liebe1*11 小时前
C语言程序代码(四)
c语言·数据结构·算法
进击的圆儿1 小时前
递归专题4 - 网格DFS与回溯
数据结构·算法·递归回溯
程序猿20231 小时前
Python每日一练---第一天:买卖股票的最佳时机
算法
夏鹏今天学习了吗2 小时前
【LeetCode热题100(56/100)】组合总和
算法·leetcode·职场和发展
ZPC82102 小时前
opencv 获取图像中物体的坐标值
人工智能·python·算法·机器人
颇有几分姿色2 小时前
密码学算法分类指南
算法·密码学
绝无仅有2 小时前
某游戏大厂的 Redis 面试必问题解析
后端·算法·面试
微笑尅乐3 小时前
三种方法解开——力扣3370.仅含置位位的最小整数
python·算法·leetcode
MMjeaty3 小时前
查找及其算法
c++·算法