45. 跳跃游戏 II

根据题解思路

在上一道题的基础上,我们可以知道最远的起跳点位置k

在这道题中,要求到达最后一个元素的最小跳跃次数,即按照最远起跳位置来计算,跳得越远,越能够早点到达最后的元素位置。

于是我们只需要在原来计算最远起跳位置的基础上,当元素遍历到这个起跳位置的时候,跳跃次数+1即可,并且更新下一次要到达的起跳点end

注意遍历元素时不要包含最后一个元素,因为在到达最后元素前的一个最远起跳位置起跳点时,跳跃次数会+1,并且更新后的下一次起跳位置一定大于等于最后一个元素位置(题中也保证了一定可以到达最后一个元素)。

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int k = 0, end = 0, ans = 0;
        for (int i = 0; i < nums.size() - 1; ++i) {
            if (k >= i) k = max(k, i + nums[i]);
            if (i == end) {
                end = k;
                ++ans;
            }
        }
        return ans;
    }
}; 
相关推荐
百度Geek说1 小时前
第一!百度智能云领跑视觉大模型赛道
算法
big_eleven1 小时前
轻松掌握数据结构:二叉树
后端·算法·面试
big_eleven1 小时前
轻松掌握数据结构:二叉查找树
后端·算法·面试
CoovallyAIHub1 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·计算机视觉
kyle~3 小时前
OpenCV---特征检测算法(ORB,Oriented FAST and Rotated BRIEF)
人工智能·opencv·算法
初学小刘3 小时前
决策树:机器学习中的强大工具
算法·决策树·机器学习
山顶风景独好3 小时前
【Leetcode】随笔
数据结构·算法·leetcode
NRatel4 小时前
Unity 游戏提升 Android TargetVersion 相关记录
android·游戏·unity·提升版本
科大饭桶4 小时前
C++入门自学Day11-- String, Vector, List 复习
c语言·开发语言·数据结构·c++·容器
lxmyzzs4 小时前
【图像算法 - 16】庖丁解牛:基于YOLO12与OpenCV的车辆部件级实例分割实战(附完整代码)
人工智能·深度学习·opencv·算法·yolo·计算机视觉·实例分割