Leetcode 55 跳跃游戏

题意理解

非负整数数组 nums,

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

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

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

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

解题思路

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

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

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

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

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

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

1.贪心解题

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

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

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表示输入数组的长度。

相关推荐
阿正的梦工坊几秒前
【Rust】11-Rust 所有权模型的编译期推理机制
开发语言·算法·rust
风筝在晴天搁浅4 分钟前
LeetCode CodeTop 88.合并两个有序数组
算法·leetcode·职场和发展
GuWen_yue5 分钟前
吃透二叉树与递归!60分钟掌握树结构核心+解题思路
javascript·算法
happymaker06267 分钟前
LeetCodeHot100——3.无重复字符的最长子串
算法
nice_lcj52011 分钟前
排序(2)-选择排序专题——简单选择排序与堆排序的结构优化
数据结构·算法·排序算法
nice_lcj52013 分钟前
排序(4)-归并排序专题——归并排序的分治美学
java·数据结构·算法·排序算法
洛水水27 分钟前
【力扣100题】83.最小栈
算法·leetcode·职场和发展
无忧.芙桃29 分钟前
数据结构之栈
c语言·开发语言·数据结构
nice_lcj52037 分钟前
排序(3)-第三篇:交换排序专题——从冒泡排序到快速排序的效率飞跃
java·数据结构·算法·排序算法
ywl47081208741 分钟前
数据结构之链表反转算法
数据结构·算法·链表