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;
    }
}
相关推荐
wuk99819 分钟前
使用PCA算法进行故障诊断的MATLAB仿真
算法·matlab
额呃呃22 分钟前
二分查找细节理解
数据结构·算法
无尽的罚坐人生28 分钟前
hot 100 283. 移动零
数据结构·算法·双指针
永远都不秃头的程序员(互关)42 分钟前
C++动态数组实战:从手写到vector优化
c++·算法
水力魔方1 小时前
武理排水管网模拟分析系统应用专题5:模型克隆与并行计算
数据库·c++·算法·swmm
谈笑也风生2 小时前
经典算法题型之排序算法(三)
java·算法·排序算法
大佬,救命!!!3 小时前
对算子shape相关的属性值自动化处理
python·算法·自动化·学习笔记·算子·用例脚本·算子形状
高山上有一只小老虎4 小时前
小红的推荐系统
java·算法
冰西瓜6004 小时前
贪心(一)——从动态规划到贪心 算法设计与分析 国科大
算法·贪心算法·动态规划
javachen__4 小时前
341-十道经典程序设计题目
数据结构·c++·算法