LeetCode刷题记录(第三天)55. 跳跃游戏

题目: 55. 跳跃游戏

标签:贪心 数组 动态规划

题目信息:

思路一:动态规划

  1. 确定dp数组含义: dp[i] 第[i]个位置能否达到
  2. 确定递推公式: dp[i] 能不能达到,取决于前面d[i-j],d[i-j]要达到,同时num[j]要大于i-j
    即 if(dp[i-j]==true&&num[j]>i-j){ dp[i] = true; }
  3. 初始化dp数组
  4. 遍历填充dp数组
  5. 检验结果

代码实现:

cpp 复制代码
class Solution {
public:
    bool canJump(vector<int>& nums) {
        int n=nums.size();
        vector<bool>dp(n,false);
        dp[0] = true;
        for(int i=0;i<n;i++){
            for(int j=n-1;j>=i;j--){
                if(dp[i]==true&&nums[i]>=j-i){
                    dp[j] = true;
                }
            }
        }
        return dp[n-1];
    }
};

时间复杂度分析:

O(n^2)

但是这道题提交后会超出时间限制

思路二:

简单思路,用k记录当前的最大跳数,k=max(k,i+nums[i]),看k能不能超过i+1,如果大于i+1,则可以到达那个地方。

代码实现:

cpp 复制代码
class Solution {
public:
    // dp超时
    bool canJump(vector<int>& nums) {
        int n=nums.size();
        int k=0;//这个就是当前最大的跳数
        for(int i=0;i<n;i++){
            if(i>k)return false;//i比最大跳数都大了,跳不了一点
            k = max(k,i+nums[i]);
        }
        return true;
    }
};

时间复杂度分析:

O(n)

总结:

太多了太多了,还有8道题目的题解来没来得及写QAQ

相关推荐
XuecWu37 小时前
原生多模态颠覆Scaling Law?解读语言“参数需求型”与视觉“数据需求型”核心差异
人工智能·深度学习·算法·计算机视觉·语言模型
We་ct7 小时前
LeetCode 69. x 的平方根:两种解法详解
前端·javascript·算法·leetcode·typescript·平方
一直不明飞行7 小时前
C++:string,写法s.find(‘@‘) != s.end()是否有问题
开发语言·c++·算法
Proxy_ZZ07 小时前
打造自己的信道编码工具箱——Turbo、LDPC、极化码三合一
c语言·算法·信息与通信
wayz117 小时前
21天机器学习核心算法学习计划(量化方向)
学习·算法·机器学习
穿条秋裤到处跑7 小时前
每日一道leetcode(2026.04.09):区间乘法查询后的异或 II
算法·leetcode
超级大只老咪7 小时前
一维度前缀和解题通用模板(java)
java·开发语言·算法
weixin_513449967 小时前
walk_these_ways项目学习记录第十篇(通过行为多样性 (MoB) 实现地形泛化)--从仿真到部署
人工智能·学习·算法
小欣加油7 小时前
leetcode 42 接雨水
c++·算法·leetcode·职场和发展
tankeven8 小时前
动态规划专题(14):石子合并问题(未完待续)
c++·算法·动态规划