45. 跳跃游戏 II - 力扣(LeetCode)

题目描述

给定一个非负整数数组,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

题目示例

输入: [2,3,1,1,4]

输出: 2

解释: 跳到最后一个位置的最小跳跃数是 2。从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。

解题思路

参考代码

java 复制代码
class Solution {
    public int jump(int[] nums) {
        // 如果数组长度为 1,不用跳直接到达终点。
        if(nums.length == 1) {
            return 0;
        }
        int curDistance = 0;    // 记录当前覆盖最远距离下标
        int nextDistance = 0;   // 记录下一步最远覆盖距离下标
        int result = 0;         // 记录步数
        for(int i = 0; i <= nums.length; i++) {
            // 更新下一步最远覆盖距离
            nextDistance = Math.max(nextDistance, i + nums[i]);
            // 遇到当前最远距离下标
            if(i == curDistance) {
                result++;
                // 更新当前最远距离下标
                curDistance = nextDistance;
                // 到达终点
                if(nextDistance >= nums.length - 1) {
                    break;
                }
            }
        }
        return result;
    }
}
相关推荐
松涛和鸣3 分钟前
41、Linux 网络编程并发模型总结(select / epoll / fork / pthread)
linux·服务器·网络·网络协议·tcp/ip·算法
鹿角片ljp6 分钟前
力扣26.有序数组去重:HashSet vs 双指针法
java·算法
XFF不秃头18 分钟前
力扣刷题笔记-合并区间
c++·笔记·算法·leetcode
巧克力味的桃子1 小时前
学习笔记:查找数组第K小的数(去重排名)
笔记·学习·算法
星云POLOAPI1 小时前
大模型API调用延迟过高?深度解析影响首Token时间的五大因素及优化方案
人工智能·python·算法·ai
88号技师1 小时前
2026年1月一区SCI-波动光学优化算法Wave Optics Optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
chengpei1471 小时前
Moonlight + Sunshine互联网串流方案介绍
游戏
向宇it1 小时前
2025年技术总结 | 在Unity游戏开发路上的持续探索与沉淀
游戏·unity·c#·游戏引擎
明朝百晓生2 小时前
强化学习[chapter8] [page17] Value Function Methods
人工智能·算法
POLITE32 小时前
Leetcode 56.合并区间 JavaScript (Day 6)
算法·leetcode·职场和发展