55.跳跃游戏

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

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

方法一:

复杂度:n * n 1

java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int idx = nums.length -1;
        // 标记最后一个位置
        numsMark[idx] = -1;
        while(idx != 0){
            // 从最后一个位置,依次向前判断每个节点是否能到达。
            // 能到达就标记出来,再向前判断。就可以判断是否能到达标记过的节点
            isNext(nums, idx-1);
            idx--;
        }
        if(nums[0] != -1) return false;
        else return true;
    }
    public void isNext(int[] nums, int idx){
        for(int i = idx; i <= idx + nums[idx]; i++){
            if(nums[i] == -1) {
                nums[idx] = -1;
                return;
            }
        }
    }
}

方法二:

复杂度:n 1

java 复制代码
public boolean canJump(int[] nums){
    // range 可达的最大范围
    int range = 0;
    // 依次前向移动,更新最大移动范围
    for(int i = 0; i <= range; i++){
        if(range >= nums.length) return true;
        range = Math.max(range, i + nums[i]);
    }
    return false;
}
相关推荐
会员源码网3 小时前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法
木心月转码ing4 小时前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
HelloReader4 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱7 小时前
二叉树分解问题思路解题模式
javascript·后端·算法
qianpeng8978 小时前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮20 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
AI软著研究员1 天前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish1 天前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱1 天前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者2 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶