hot100-64跳跃游戏

一、题目

给定一个非负数数组nums,最初位于数组的第一个下标。数组中的每个元素代表在该位置可以跳跃的最大长度。判断是否可以到达最后一个下标,如果可以,返回true,否则返回false。

二、思路

1、贪心算法:维护一个变量 farthest 表示当前能够到达的最远位置,从左到右遍历数组,每到一个位置就尝试用它来更新最远可达范围(farthest = max(farthest, i + nums[i]))。

如果在遍历过程中发现当前位置 i 已经超出了当前能到达的最远位置(即 i > farthest),说明无法继续前进,直接返回 false。

只要在某一步中 farthest 达到或超过最后一个下标,就说明可以跳到最后,返回 true。整个过程只需一次遍历。

三、代码

java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int farthest = 0; // 当前能到达的最远位置
        
        for (int i = 0; i < nums.length; i++) {
            // 如果当前位置无法到达,直接返回 false
            if (i > farthest) {
                return false;
            }
            
            // 更新最远可达位置
            farthest = Math.max(farthest, i + nums[i]);
            
            // 如果已经能到达最后一个位置,提前返回 true
            if (farthest >= nums.length - 1) {
                return true;
            }
        }
        
        return true;
    }
}
相关推荐
杨连江几秒前
载流子矩阵限域束缚实现常温常压超导的理论与结构设计
算法
bzmK1DTbd3 分钟前
Java游戏服务器:Netty框架的高并发网络通信
java·服务器·游戏
做cv的小昊9 分钟前
【TJU】研究生应用统计学课程笔记(6)——第二章 参数估计(2.4 区间估计)
人工智能·笔记·线性代数·算法·机器学习·数学建模·概率论
普贤莲花16 分钟前
【2026年第18周---写于20260501】---舍得
程序人生·算法·leetcode
2zcode16 分钟前
基于深度学习的口腔疾病图像识别系统(UI界面+改进算法+数据集+训练代码)
人工智能·深度学习·算法
Sarvartha26 分钟前
N 个字符串最长公共子序列(LCS)求解问题
数据结构·算法
一切皆是因缘际会26 分钟前
下一代 AI 架构:基于记忆演化与单向投影的安全智能系统
大数据·人工智能·深度学习·算法·安全·架构
falldeep32 分钟前
五分钟了解OpenClaw底层架构
人工智能·算法·机器学习·架构
m0_6294947332 分钟前
LeetCode 热题 100-----16.除了自身以外数组的乘积
数据结构·算法·leetcode
weixin_4462608539 分钟前
模型能力深度对决:GPT-4o、Claude 3.5和DeepSeek V系列模型的横向评测与未来趋势洞察
人工智能·算法·机器学习