45. 跳跃游戏 II

题目描述

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

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

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

返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]

示例

示例 1:

复制代码
输入: nums = [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。
     从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。

示例 2:

复制代码
输入: nums = [2,3,0,1,4]
输出: 2

提示:

  • 1 <= nums.length <= 10^4
  • 0 <= nums[i] <= 1000
  • 题目保证可以到达 nums[n-1]

代码

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int max_far=0;  //能到达最远距离
        int s=0;         // 最少跳跃次数
        int r=0;        //每次能达到的最右边界
        for(int i=0;i<nums.size()-1;i++)
        {
            max_far = max(max_far,i+nums[i]);  // 跳的位置
            if(i==r)
            { 
                r = max_far;            // 下一个起跳位置
                s++;                  
            }
        }
        return s;
    }
    
};
相关推荐
BingLin-Liu10 小时前
蓝桥杯备考---》贪心算法之矩阵消除游戏
算法·游戏·贪心算法
苹果企业签名分发20 小时前
游戏搭建云服务器配置推荐
运维·服务器·游戏
二狗哈1 天前
go游戏后端开发20:房间消息推送处理
开发语言·游戏·golang
fatiaozhang95272 天前
晶晨S905L3A(B)-安卓9.0-开启ADB和ROOT-支持IPTV6-支持外置游戏系统-支持多种无线芯片-支持救砖-完美通刷线刷固件包
android·游戏·adb·华为·电视盒子·机顶盒rom·魔百盒固件
腾讯安全应急响应中心2 天前
命悬生死线:当游戏遭遇DDoS围剿,如何用AI破局?
网络·人工智能·游戏·ddos
徐礼昭|商派软件市场负责人2 天前
2025年消费观念转变与行为趋势全景洞察:”抽象、符号、游戏、共益、AI”重构新世代消费价值的新范式|徐礼昭
大数据·人工智能·游戏·重构·零售·中产阶级·消费洞察
CodeCaptain3 天前
[推荐了解]各类游戏引擎入门选择说明
经验分享·游戏
zzj_2626103 天前
Java课程设计(双人对战游戏)持续更新......
java·游戏·课程设计
米芝鱼4 天前
LearnOpenGL(九)自定义转换类
开发语言·c++·算法·游戏·图形渲染·shader·opengl
Footprint_Analytics5 天前
3.17-3.23 Web3 游戏周报:Pixudi 双榜领跑,The Forgotten Runiverse 登陆三大主机平台
游戏·web3