力扣HOT100-跳跃游戏II

给定一个长度为 n0 索引 整数数组 nums。初始位置在下标 0。

每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说,如果你在索引 i 处,你可以跳转到任意 (i + j) 处:

  • 0 <= j <= nums[i]
  • i + j < n

返回到达 n - 1 的最小跳跃次数。测试用例保证可以到达 n - 1

代码:

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int n=nums.size();
        int current_end=0;//本次跳跃的最远位置
        int fastest=0;//下次可以跳到的最远位置
        int times=0;
        if(n<=1) return times;
        for(int i=0;i<n;++i)
        {
            fastest=max(fastest,i+nums[i]);
            if(i==current_end)
            {
                current_end=fastest;
                times++;

                if(current_end>=n-1)
                {
                    return times;
                }
            }
        }

        return times;
    }
};

**解题思路:**使用贪心策略。用current_end记录本次跳跃可到的最远位置,记录每个位置可跳跃到的最远位置,用它们的最大值不断更新fastest。这样当i==current_end时,fastest的值就是本次跳跃中可到达的下次跳跃的最远位置,直接用fastest更新current_end,最终得到的times就是到达n-1位置的最小跳跃次数。

时间复杂度:O(n)

算法中只有一个 for 循环,遍历了数组一次(从索引 0 到 n-2)

循环内部的操作(比较、赋值等)都是常数时间 O (1)

因此整体时间复杂度为 O (n),其中 n 是数组 nums 的长度
空间复杂度:O(1)

算法只使用了有限的几个额外变量(jumps、current_end、farthest 等)

这些变量的数量与输入规模 n 无关,不随 n 的变化而变化

因此空间复杂度为常数阶 O (1)

相关推荐
码云数智-大飞11 分钟前
分布式锁的“双雄对决”:Redis 与 ZooKeeper 的深度博弈与选型指南
算法
cpp_250118 分钟前
P1910 L 国的战斗之间谍
数据结构·c++·算法·题解·洛谷·背包dp
yu859395820 分钟前
时延估计的互相关算法(MATLAB实现)
开发语言·算法·matlab
逸风尊者22 分钟前
2026 主流 Claw 类产品技术报告
人工智能·后端·算法
强盛机器学习~27 分钟前
考虑异常天气和太阳辐射下基于强化学习的无人机三维路径规划
算法·matlab·无人机·强化学习·路径规划·无人机路径规划·q-learning
Pixlout31 分钟前
《7元接口体系》v1.0
网络·算法·硬件工程
SUNNY_SHUN32 分钟前
不需要Memory Bank:CMDR-IAD用2D+3D双分支重建做工业异常检测,MVTec 3D 97.3%
论文阅读·人工智能·算法·3d
Matlab光学37 分钟前
Matlab 复现:分数阶&整数阶OAM 变换
算法·matlab·拓扑学
凌波粒1 小时前
LeetCode--459.重复的子字符串(字符串/KMP算法)
算法·leetcode·职场和发展
_深海凉_1 小时前
LeetCode热题100-移除元素
数据结构·算法·leetcode