贪心算法-跳跃游戏II

45.跳跃游戏II

java 复制代码
给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。

每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:

0 <= j <= nums[i] 
i + j < n
返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]。

输入 :数组
输出 :整型
思路

  1. 从右往左,先让position等于最右边,然后遍历数组,找到最小能到达的下标,然后更新position,直到position==0
java 复制代码
class Solution {
    public int jump(int[] nums) {
        int position = nums.length - 1;
        int step = 0;
        while(position != 0){
            for(int i = 0; i < position; i++){
                if(i + nums[i] >= position){
                    position = i;
                    step++;
                    break;
                    }
                }
            }
            return step;
        }
    }
}

方法一虽然可以实现,但是时间复杂度高O(n2)

  1. 使用正向遍历,记录可以到达的最远位置
java 复制代码
class Solution {
    public int jump(int[] nums) {
        int len = nums.length;
        int end = 0;
        int maxPosition = 0;
        int step = 0;
        for(int i = 0; i < len - 1; i++){
            maxPosition = Math.max(maxPosition, i + nums[i]);
            if(i == end){
                end = maxPosition;
                step++;
            }
        }
        return step;
    }
}

注意两点

  • 对于if(end == i)的理解
  • 对于不需要遍历到最后一个元素的理解
相关推荐
LYFlied39 分钟前
【每日算法】LeetCode 136. 只出现一次的数字
前端·算法·leetcode·面试·职场和发展
唯唯qwe-1 小时前
Day23:动态规划 | 爬楼梯,不同路径,拆分
算法·leetcode·动态规划
做科研的周师兄1 小时前
中国土壤有机质数据集
人工智能·算法·机器学习·分类·数据挖掘
来深圳2 小时前
leetcode 739. 每日温度
java·算法·leetcode
yaoh.wang2 小时前
力扣(LeetCode) 104: 二叉树的最大深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
hetao17338372 小时前
2025-12-21~22 hetao1733837的刷题笔记
c++·笔记·算法
醒过来摸鱼2 小时前
递归三种分类方法
算法
炽烈小老头3 小时前
【每天学习一点算法 2025/12/22】将有序数组转换为二叉搜索树
学习·算法
jghhh013 小时前
POCS(凸集投影)算法解决部分k空间数据缺失导致吉布斯伪影
算法
罗湖老棍子3 小时前
最小函数值(minval)(信息学奥赛一本通- P1370)
数据结构·c++·算法··优先队列·