跳跃游戏(动态规划)

给你一个非负整数数组 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 分钟前
【求中位数】2024-1-23
c语言·c++·经验分享·笔记·算法
地平线开发者44 分钟前
PTQ 量化数值范围与优化
算法·自动驾驶
sali-tec1 小时前
C# 基于halcon的视觉工作流-章68 深度学习-对象检测
开发语言·算法·计算机视觉·重构·c#
测试人社区-小明1 小时前
智能弹性伸缩算法在测试环境中的实践与验证
人工智能·测试工具·算法·机器学习·金融·机器人·量子计算
罗西的思考2 小时前
【Agent】MemOS 源码笔记---(5)---记忆分类
人工智能·深度学习·算法
BT-BOX3 小时前
普中开发板基于51单片机贪吃蛇游戏设计
单片机·游戏·51单片机
90后小陈老师4 小时前
Unity教学 项目2 2D闯关游戏
游戏·unity·游戏引擎
qq_433554545 小时前
C++数位DP
c++·算法·图论
AshinGau5 小时前
Softmax 与 交叉熵损失
神经网络·算法
似水এ᭄往昔5 小时前
【C++】--AVL树的认识和实现
开发语言·数据结构·c++·算法·stl