Leetcode 55 跳跃游戏

题意理解

非负整数数组 nums,

最初位于数组的 第一个下标

数组中的每个元素代表你在该位置可以跳跃的最大长度。

需要跳到nums最后一个元素即为成功。

目标:是否能够跳到最后一个元素。

解题思路

使用贪心算法来解题,需要理解局部解和最优解的关系。

这里引入一个覆盖区间的概念,覆盖区间表示所有可达的位置

覆盖区间覆盖到最后一个元素时,即为最后一个位置可达。

局部最最优解:当前位置尽可能到达足够远的位置,逐步探索可到达的最远位置能否覆盖到最后一个元素。

结束的位置是能探索到的最远位置。

例1:最开始的最远距离是nums[2], 在[0,2]之间探索,最远到达nums[4],即能到达最远的位置。

1.贪心解题

我们用一个cover表示最远可到达的位置。cover随着探索会不断往后移,直到最远可达位置。

注意: i+nums[i]表达当前可达的最远位置的下标。

java 复制代码
public boolean canJump(int[] nums) {
        if(nums.length==1) return true;//一个位置一定可达
        int cover=0;
        for(int i=0;i<=cover;i++){
            //i+nums[i]表示当前位置可达的最远距离的坐标
            cover=Math.max(cover,i+nums[i]);
            //最后一个位置是否可达
            if(cover>=nums.length-1) return true;
        }
        return false;
    }

2.分析

时间复杂度:O(n)

空间复杂度:O(n)

n表示输入数组的长度。

相关推荐
AndrewHZ25 分钟前
【图像处理基石】什么是油画感?
图像处理·人工智能·算法·图像压缩·视频处理·超分辨率·去噪算法
.格子衫.26 分钟前
015枚举之滑动窗口——算法备赛
数据结构·算法
J先生x1 小时前
【IP101】图像处理进阶:从直方图均衡化到伽马变换,全面掌握图像增强技术
图像处理·人工智能·学习·算法·计算机视觉
爱coding的橙子4 小时前
每日算法刷题 Day3 5.11:leetcode数组2道题,用时1h(有点慢)
算法·leetcode
Dream it possible!7 小时前
LeetCode 热题 100_只出现一次的数字(96_136_简单_C++)(哈希表;哈希集合;排序+遍历;位运算)
c++·leetcode·位运算·哈希表·哈希集合
?abc!9 小时前
缓存(5):常见 缓存数据淘汰算法/缓存清空策略
java·算法·缓存
BioRunYiXue9 小时前
一文了解氨基酸的分类、代谢和应用
人工智能·深度学习·算法·机器学习·分类·数据挖掘·代谢组学
jiunian_cn10 小时前
【c++】异常详解
java·开发语言·数据结构·c++·算法·visual studio
工藤新一¹11 小时前
蓝桥杯算法题 -蛇形矩阵(方向向量)
c++·算法·矩阵·蓝桥杯·方向向量
Levin__NLP_CV_AIGC11 小时前
解决pip安装PyPI默认源速度慢
算法·pip