【贪心算法】 55. 跳跃游戏

55. 跳跃游戏

解题思路

  • 定义变量 n 来存储数组 nums 的长度。
  • 初始化 farthest 变量为 0,用于记录当前能够到达的最远距离。
  • 使用一个 for 循环遍历数组,但是不包括数组的最后一个元素,因为我们的目标是看是否能到达最后一个位置。
  • 在循环内部,使用 Math.max(farthest, i + nums[i]) 来更新 farthest,这表示当前能到达的最远距离是之前计算的 farthest 和*当前位置加上当前位置能跳的最远距离中的较大值。
  • 如果在某一刻 farthest 小于或等于当前位置 i,意味着无法前进,因此返回 false。
  • 循环结束后,如果 farthest 大于或等于数组最后一个位置的索引,表示可以到达最后,返回 true
java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int n = nums.length;
        int farthest = 0;

        for(int i = 0; i < n - 1; i++){
            farthest = Math.max(farthest,i + nums[i]);// 更新最远的跳跃距离

            if(farthest <= i){
                return false;
            }
        }

        return farthest >= n - 1;// 最大长度大于最后一个位置索引 表示可以到达
    }
}
相关推荐
源代码•宸8 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang
yongui478348 小时前
MATLAB的指纹识别系统实现
算法
高山上有一只小老虎8 小时前
翻之矩阵中的行
java·算法
jghhh018 小时前
RINEX文件进行卫星导航解算
算法
爱思德学术9 小时前
中国计算机学会(CCF)推荐学术会议-A(计算机科学理论):LICS 2026
算法·计算机理论·计算机逻辑
CVHub9 小时前
多模态图文训推一体化平台 X-AnyLabeling 3.0 版本正式发布!首次支持远程模型推理服务,并新增 Qwen3-VL 等多款主流模型及诸多功能特性,等
算法
hoiii1879 小时前
MATLAB实现Canny边缘检测算法
算法·计算机视觉·matlab
qq_430855889 小时前
线代第二章矩阵第四课:方阵的幂
算法·机器学习·矩阵
roman_日积跬步-终至千里9 小时前
【计算机设计与算法-习题2】动态规划应用:矩阵乘法与钢条切割问题
算法·矩阵·动态规划
kupeThinkPoem9 小时前
计算机算法导论第三版算法视频讲解
数据结构·算法