跳跃游戏(动态规划)

给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。

示例 1:

输入:nums = [2,3,1,1,4]

输出:true

解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。

示例 2:

输入:nums = [3,2,1,0,4]

输出:false

解释:无论怎样,总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 , 所以永远不可能到达最后一个下标。

解法:

js 复制代码
/**
 * @param {number[]} nums
 * @return {boolean}
 * 记录一个最后一位的下标,然后依次向前寻找满足跳跃条件的下标,并将该下标与记录的下标替换。直到找到下标为0,才算是到达最后一个下标。
 */
var canJump = function(nums) {
    let endIndex = nums.length - 1;
    for(let i = nums.length -2;i>=0;i--){
        if(endIndex-i<=nums[i]){
            endIndex = i
        }
    }
    return endIndex === 0
};
相关推荐
进击的荆棘12 小时前
优选算法——滑动窗口
c++·算法·leetcode
csdn_aspnet12 小时前
奈飞工厂算法:个性化推荐系统的极限复刻
算法·netflix·奈飞
小白_ysf12 小时前
Vue 中常见的加密方法(对称、非对称、杂凑算法)
前端·vue.js·算法
ujainu13 小时前
Flutter + OpenHarmony 游戏开发进阶:粒子系统初探——简易爆炸与得分飞字
flutter·游戏·openharmony
多米Domi01113 小时前
0x3f 第49天 面向实习的八股背诵第六天 过了一遍JVM的知识点,看了相关视频讲解JVM内存,垃圾清理,买了plus,稍微看了点确定一下方向
jvm·数据结构·python·算法·leetcode
A_nanda1 天前
c# MOdbus rto读写串口,如何不相互影响
算法·c#·多线程
代码雕刻家1 天前
2.4.蓝桥杯-分巧克力
算法·蓝桥杯
Ulyanov1 天前
顶层设计——单脉冲雷达仿真器的灵魂蓝图
python·算法·pyside·仿真系统·单脉冲
智者知已应修善业1 天前
【查找字符最大下标以*符号分割以**结束】2024-12-24
c语言·c++·经验分享·笔记·算法
91刘仁德1 天前
c++类和对象(下)
c语言·jvm·c++·经验分享·笔记·算法