贪心算法-跳跃游戏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)的理解
  • 对于不需要遍历到最后一个元素的理解
相关推荐
暮志未晚Webgl1 天前
UE5使用CameraShake相机震动提升游戏体验
数码相机·游戏·ue5
2301_765703141 天前
C++中的职责链模式实战
开发语言·c++·算法
StandbyTime1 天前
《算法笔记》学习记录-第一章
c++·算法·算法笔记
近津薪荼1 天前
优选算法——双指针8(单调性)
数据结构·c++·学习·算法
格林威1 天前
Baumer相机铆钉安装状态检测:判断铆接是否到位的 5 个核心算法,附 OpenCV+Halcon 的实战代码!
人工智能·opencv·算法·计算机视觉·视觉检测·工业相机·堡盟相机
星空露珠1 天前
速算24点检测生成核心lua
开发语言·数据库·算法·游戏·lua
中二病码农不会遇见C++学姐1 天前
《文明6》Leaders.xml 文件标签解析指南
游戏
happygrilclh1 天前
高压高频电源的pid算法
算法
格林威1 天前
Baumer相机铸件气孔与缩松识别:提升铸造良品率的 6 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·opencv·算法·安全·计算机视觉·堡盟相机·baumer相机
你好!蒋韦杰-(烟雨平生)1 天前
OpenGL
c++·数学·游戏·3d