跳跃游戏 | 贪心算法最优解(LeetCode经典题)

跳跃游戏 | 贪心算法最优解(LeetCode经典题)

题目描述

给定一个非负整数数组 nums,你最初位于数组的第一个下标。数组中每个位置的元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达数组的最后一个下标,能则返回 true,不能则返回 false

核心特征分析

  1. 处理对象为数组类问题,这类问题通常可优先考虑动态规划或贪心算法解决;
  2. 题目中"每个位置的元素代表能跳跃的最大长度"是贪心算法的典型应用特征------无需关注具体跳跃路径,只需聚焦"能到达的最远范围"即可验证可行性。

算法选择与思路

算法选择

本题仅需验证"能否到达最后一个下标"的可行性,无需罗列具体跳跃路径,因此选择贪心算法是最优解(相比动态规划,贪心算法时间复杂度相同且空间复杂度更低)。

贪心算法核心思路

  1. 维护变量 max_length,表示当前能到达的最大索引位置;
  2. 遍历数组中的每个索引 i
    • 若当前索引 i 超过 max_length,说明无法到达该位置,直接返回 false
    • 更新 max_lengthmax(max_length, i + nums[i])(当前能到达的最远位置 = 历史最远位置 和 当前位置可跳最远位置 的较大值);
    • max_length 已≥数组最后一个索引,说明能到达终点,直接返回 true
  3. 遍历结束后,兜底判断 max_length 是否≥数组最后一个索引(适配数组长度为1等边界场景)。

完整解题代码

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

复杂度分析

  • 时间复杂度 :O(n)。仅需遍历一次数组,n 为数组长度;
  • 空间复杂度 :O(1)。仅使用常数级额外空间(max_lengthni 三个变量)。

总结

  1. 跳跃游戏可行性验证的核心是维护"能到达的最远索引",贪心算法是该问题的最优解法;
  2. 遍历中提前终止判断(无法到达当前索引/已确认能到终点时直接返回),可提升实际执行效率;
  3. 该解法时间复杂度 O(n)、空间复杂度 O(1),是本题的最优解。
相关推荐
71-3几秒前
C语言练习——数组的练习(涉及顺序、二分查找,冒泡排序)
c语言·笔记·学习·排序算法·查找算法
七颗糖很甜几秒前
预警!超级厄尔尼诺即将登场:2026-2027年全球气候或迎“极端狂暴模式”
java·大数据·python·算法·github
格林威1 分钟前
面阵相机 vs 线阵相机:堡盟与Basler选型差异全解析 + Python实战演示
开发语言·网络·人工智能·python·数码相机·yolo·工业相机
Brilliantwxx2 分钟前
【C++】类与对象(下)
c++·笔记·算法
qq_283720052 分钟前
Chroma 向量数据库详细介绍与实战全攻略
数据库·人工智能·向量数据库·chroma
深蓝海拓3 分钟前
基于QtPy (PySide6) 的PLC-HMI工程项目(十二)最后的工作
网络·笔记·python·学习·pyqt·plc
qq_411262424 分钟前
四博 CozyLife WiFi AI 智能音箱 S3 技术方案
人工智能·智能音箱
@insist1234 分钟前
信息安全工程师-密码学专题(上):密码学核心框架与基础体系梳理
算法·密码学·软考·信息安全工程师·软件水平考试
承渊政道4 分钟前
【动态规划算法】(从入门到精通:路径问题)
数据结构·c++·学习·算法·leetcode·macos·动态规划
武帝为此5 分钟前
【数据质量校验简介】
人工智能·python·机器学习