LeetCode.55 跳跃游戏

LeetCode.55 跳跃游戏

题目描述

解题思路

错误的解题思路

我一开始的思路是累加可跳范围内的最大值sum,如果最终sum >= nums.size()那么就返回true,这种思路是错误的,因为在你选择最大值的时候,你并没有对每个格子选择能跳最远的距离进行跳跃。

解题思路

  • 如果某一个作为 起跳点 的格子可以跳跃的距离是 3,那么表示后面 3 个格子都可以作为 起跳点
  • 可以对每一个能作为 起跳点 的格子都尝试跳一次,把 能跳到最远的距离 不断更新
  • 如果可以一直跳到最后,就成功了

代码

cpp 复制代码
class Solution {
public:
    bool canJump(vector<int>& nums) {
        int max_cover = 0;
        for (int i = 0; i < nums.size(); i++) {
            if (max_cover < i) return false;
            max_cover = max(nums[i] + i, max_cover);
        }
        return true;
    }
};
相关推荐
我是中国人哦(⊙o⊙)12 分钟前
我的寒假作业
人工智能·算法·机器学习
.格子衫.26 分钟前
030动态规划之树形DP——算法备赛
算法·动态规划
胡萝卜不甜43 分钟前
算法宗门--冒泡排序(“懒”到极致的算法)
算法
charliejohn1 小时前
计算机考研 408 数据结构 中缀转后缀
数据结构·考研·算法
lifallen1 小时前
后缀数组 (Suffix Array)
java·数据结构·算法
仰泳的熊猫1 小时前
题目1523:蓝桥杯算法提高VIP-打水问题
数据结构·c++·算法·蓝桥杯
汉克老师1 小时前
GESP2024年3月认证C++二级( 第三部分编程题(1) 乘法问题)
c++·算法·循环结构·gesp二级·gesp2级
juleskk1 小时前
2.18复试训练
算法
tankeven2 小时前
HJ94 记票统计
c++·算法
逆境不可逃2 小时前
LeetCode 热题 100 之 76.最小覆盖子串
java·算法·leetcode·职场和发展·滑动窗口