leetcode 55. 跳跃游戏

2023.7.29

本题不用纠结于可以跳几步,可以聚焦于**覆盖范围,**即 当前位置+当前跳数 能够覆盖的范围,若这个范围足以到达最后一个位置,则返回true;若for循环结束,则还没返回true,则返回false。 下面看代码:

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

ps:因为cover是覆盖范围,所以for循环的终止条件是i<=cover,最后一个位置是可以取到的。

相关推荐
爱搞事的程小猿12 分钟前
qml自定义扩展模块
c++·qt·qml
喜欢吃燃面12 分钟前
基础算法:高精度
开发语言·c++·学习·算法
堕27414 分钟前
java数据结构当中的《Lambda表达式》
java·数据结构·python
new_zhou17 分钟前
Windows环境c++开发dump文件生成(优化方案)
c++·windows·qt
wengqidaifeng26 分钟前
数据结构(三)栈和队列(下)队列:程序世界的秩序之美
数据结构
努力学算法的蒟蒻27 分钟前
day84(2.12)——leetcode面试经典150
算法·leetcode·面试
程序员酥皮蛋30 分钟前
hot 100 第二十三题 23.反转链表
数据结构·算法·leetcode·链表
你的冰西瓜30 分钟前
C++中的queue容器详解
开发语言·c++·stl
蜡笔小马35 分钟前
Boost.Polygon 库概述:高效处理平面多边形几何的利器
c++·boost
TracyCoder1231 小时前
LeetCode Hot100(51/100)——155. 最小栈
数据结构·算法·leetcode