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

相关推荐
智者知已应修善业18 分钟前
【给定英文字符串统计最多小写最前输出】2023-2-27
c语言·开发语言·c++·经验分享·笔记·算法
RWKV元始智能24 分钟前
体验RWKV-7训练全过程,只需400行代码训练3分钟
人工智能·算法·机器学习
点云SLAM39 分钟前
四元数 (Quaternion)微分-四元数导数的矩阵表示推导(8)
线性代数·算法·计算机视觉·矩阵·机器人·slam·四元数
kyle~1 小时前
算法---贪心算法(Greedy Algorithm)
算法·贪心算法
fashion 道格1 小时前
C 语言数组拼接:从基础实现到细节优化
算法
爱吃烤鸡翅的酸菜鱼2 小时前
网易UU远程全功能技术解构:游戏级性能突围与安全边界探析
安全·游戏·远程工作·uu加速器
头发还没掉光光2 小时前
Linux多线程之自旋锁与读写锁
linux·运维·算法
fashion 道格2 小时前
C 语言希尔排序:原理、实现与性能深度解析
数据结构·算法·排序算法
初夏睡觉2 小时前
P1048 [NOIP 2005 普及组] 采药
数据结构·c++·算法
小欣加油2 小时前
leetcode 1513 仅含1的子串数
c++·算法·leetcode·职场和发展