面试经典150题——跳跃游戏

面试经典150题 day9

      • 题目来源
      • 我的题解
        • [方法一 动态规划+双重循环](#方法一 动态规划+双重循环)
        • [方法二 贪心](#方法二 贪心)

题目来源

力扣每日一题;题序:55

我的题解

方法一 动态规划+双重循环

使用一个dp表记录i位置是否可达,然后在判断是否可达时需要看前面的nums[j]+j>=i&&dp[j]。
时间复杂度 :O( n 2 n^2 n2)
空间复杂度:O(n)

java 复制代码
public boolean canJump(int[] nums) {
    int n=nums.length;
    boolean[] dp=new boolean[n];
    dp[0]=true;
    for(int i=1;i<n;i++){
        for(int j=0;j<i;j++){
            if(nums[j]+j>=i&&dp[j])
                dp[i]=true;
        }
    }
    return dp[n-1];
}
方法二 贪心

记录当前能够达到的最大位置,若能达到的最大位置小于当前位置,则返回false;若能达到的最大位置大于等于n-1,则返回true,其他情况返回false。
时间复杂度:O(n)

空间复杂度:O(1)

java 复制代码
public boolean canJump(int[] nums) {
    int n=nums.length;
    int maxIndex=0;
    for(int i=0;i<n;i++){
        if(maxIndex<i)
            return false;
        maxIndex=Math.max(maxIndex,nums[i]+i);
        if(maxIndex>=n-1)
            return true;
    }
    return false;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
MarkHD4 分钟前
智能体在车联网中的应用:第31天 基于RLlib的多智能体PPO实战:MAPPO算法解决simple_spread合作任务
算法
IT猿手5 分钟前
三维动态避障路径规划:基于部落竞争与成员合作算法(CTCM)融合动态窗口法DWA的无人机三维动态避障方法研究,MATLAB代码
算法·matlab·动态规划·无人机·路径规划·动态路径规划
老华带你飞10 分钟前
电商系统|基于java + vue电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
菠菠萝宝20 分钟前
从传统后端到AI智能驱动:Java + AI 生态深度实战技术总结
java·人工智能·ai·llm·知识图谱·ai编程·rag
陈佳梁22 分钟前
java--对象的引用
java·开发语言
wadesir23 分钟前
Java实现遗传算法(从零开始掌握智能优化算法)
java·开发语言·算法
Jeremy爱编码26 分钟前
leetcode热题腐烂的橘子
算法·leetcode·职场和发展
程序媛徐师姐36 分钟前
Java基于SpringBoot的智能城市管理平台,附源码+文档说明
java·spring boot·java springboot·智能城市管理平台·java智能城市管理平台·java智能城市管理·智能城市管理
H CHY38 分钟前
C++代码
c语言·开发语言·数据结构·c++·算法·青少年编程
alphaTao40 分钟前
LeetCode 每日一题 2025/12/22-2025/12/28
算法·leetcode