【面试经典150 | 数组】跳跃游戏 II

文章目录

写在前面

本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更......
专栏内容以分析题目为主,并附带一些对于本题涉及到的数据结构等内容进行回顾与总结,文章结构大致如下,部分内容会有增删:

  • Tag:介绍本题牵涉到的知识点、数据结构;
  • 题目来源:贴上题目的链接,方便大家查找题目并完成练习;
  • 题目解读:复述题目(确保自己真的理解题目意思),并强调一些题目重点信息;
  • 解题思路:介绍一些解题思路,每种解题思路包括思路讲解、实现代码以及复杂度分析;
  • 知识回忆:针对今天介绍的题目中的重点内容、数据结构进行回顾总结。

Tag

【贪心】【数组】


题目来源

面试经典150 | 45. 跳跃游戏 II


题目解读

给你一个长度为 n 的数组 numsnums[i] 表示你可以从下标 i 往后(往索引变大的方向)跳跃的最大长度,你可以向后跳跃任何距离(该距离在 0nums[i] 内)。返回到达 nums[n-1] 的最小跳跃步数。

题目要求我们求出从位置 0 开始到数组位置 n-1 处跳跃的最小步数。


解题思路

方法一:贪心

我们使用贪心的思想进行解答,贪心的思想即通过局部最优解得到全局最优解。

我们在每次可以跳跃的步数中,选择可以到达最远位置的位置作为起跳点进行跳跃。

例如,对于数组 nums = [2, 1, 3, 4],我们初始位置从下标 0 开始跳跃,可以跳跃到下标 1 和下标 2,其中下标 1 的值为 1,下标 2 的值为 3,因此第一次到达的下标我们选择到达 2

在具体的实现中,我们维护当前能够到达的最大下标位置,记为边界 end。我们从左到右遍历数组,到达边界时,更新边界并将跳跃次数增加 1

在遍历数组时,我们不访问最后一个元素,这是因为在访问最后一个元素之前,我们的边界一定大于等于最后一个位置,否则就无法跳到最后一个位置了。如果访问最后一个元素,在边界正好为最后一个位置的情况下,我们会增加一次不必要的跳跃次数,因此我们不必访问最后一个元素。

以上两端文字出自于 官方题解,还需好好体会。

实现代码

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int maxPos = 0, n = nums.size(), end = 0, step = 0;
        for (int i = 0; i < n - 1; ++i) {
            if (maxPos >= i) {
                maxPos = max(maxPos, i + nums[i]);
                if (i == end) {
                    end = maxPos;
                    ++step;
                }
            }
        }
        return step;
    }
};

复杂度分析

时间复杂度: O ( n ) O(n) O(n)。

空间复杂度: O ( 1 ) O(1) O(1)。


写在最后

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。

最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。

相关推荐
weixin_478689763 分钟前
C++ 对 C 的兼容性
java·c语言·c++
k要开心8 分钟前
C++概念以及基础框架语法
开发语言·c++
hn小菜鸡20 分钟前
LeetCode 1356.根据数字二进制下1的数目排序
数据结构·算法·leetcode
zhuiQiuMX24 分钟前
分享今天做的力扣SQL题
sql·算法·leetcode
weixin_3077791330 分钟前
Linux下GCC和C++实现统计Clickhouse数据仓库指定表中各字段的空值、空字符串或零值比例
linux·运维·c++·数据仓库·clickhouse
music&movie2 小时前
算法工程师认知水平要求总结
人工智能·算法
秦少游在淮海2 小时前
C++ - string 的使用 #auto #范围for #访问及遍历操作 #容量操作 #修改操作 #其他操作 #非成员函数
开发语言·c++·stl·string·范围for·auto·string 的使用
const5442 小时前
cpp自学 day2(—>运算符)
开发语言·c++
虾球xz2 小时前
CppCon 2015 学习:CLANG/C2 for Windows
开发语言·c++·windows·学习
laocui12 小时前
Σ∆ 数字滤波
人工智能·算法