【面试经典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)。


写在最后

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

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

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

相关推荐
序属秋秋秋12 分钟前
《Linux系统编程之进程基础》【进程状态】
linux·运维·c语言·c++·笔记·操作系统·进程状态
啊吧怪不啊吧33 分钟前
贪心算法(局部最优实现全局最优)第一篇
算法·贪心算法
利刃大大1 小时前
【c++中间件】etcd存储系统 && 服务注册 && 服务发现 && 二次封装
c++·中间件·服务发现·etcd·服务中心
Yue丶越1 小时前
【C语言】深入理解指针(四)
java·c语言·算法
报错小能手1 小时前
C++笔记 仿函数(函数对象)
开发语言·c++·笔记
Abona1 小时前
自动驾驶、无人机、机器人核心技术双范式
算法·机器人·自动驾驶·无人机
草莓熊Lotso1 小时前
《算法闯关指南:优选算法--模拟》--39.替换所有问号,40.提莫攻击
开发语言·c++·算法·模拟
艾莉丝努力练剑2 小时前
【Linux基础开发工具 (三)】Vim从入门到精通(下):效率翻倍的编辑技巧与个性化配置攻略
linux·运维·服务器·c++·ubuntu·centos·vim
草莓熊Lotso2 小时前
C++ STL set 系列完全指南:从底层原理、核心接口到实战场景
开发语言·c++·人工智能·经验分享·网络协议·算法·dubbo
做怪小疯子4 小时前
LeetCode 热题 100——子串——和为 K 的子数组
算法·leetcode·职场和发展