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

相关推荐
孞㐑¥1 分钟前
算法—哈希表
开发语言·c++·经验分享·笔记·算法
近津薪荼16 分钟前
递归专题(2)——合并链表
c++·学习·算法·链表
Asher阿舍技术站17 分钟前
【数字通信理论系列】四、载波相位同步
算法·载波同步
圣保罗的大教堂17 分钟前
leetcode 3013. 将数组分成最小总代价的子数组 II 困难
leetcode
-Try hard-21 分钟前
队列 | 二叉树
算法
Sagittarius_A*23 分钟前
灰度变换与阈值化:从像素映射到图像二值化的核心操作【计算机视觉】
图像处理·人工智能·opencv·算法·计算机视觉·图像阈值·灰度变换
中二病码农不会遇见C++学姐31 分钟前
文明6 Mod入门:三分钟学会用SQL制作第一个修改器
sql·游戏
Nie_Xun32 分钟前
卡尔曼滤波(EKF/IEKF)与非线性优化(高斯-牛顿法)的统一关系
算法
仰泳的熊猫1 小时前
题目1433:蓝桥杯2013年第四届真题-危险系数
数据结构·c++·算法·蓝桥杯·深度优先·图论
平哥努力学习ing1 小时前
补充 part 1——防御性编程
算法