【力扣】55. 跳跃游戏 <贪心>

【力扣】55. 跳跃游戏

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

示例 1:

输入:nums = 2,3,1,1,4

输出:true

解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。

示例 2:

输入:nums = 3,2,1,0,4

输出:false

解释:无论怎样,总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 , 所以永远不可能到达最后一个下标。

提示:

1 <= nums.length <= 1 0 4 10^4 104

0 <= numsi <= 1 0 5 10^5 105

题解

走一步就更新可以走最远的距离,比最远距离小的位置都可以到达。

java 复制代码
public class Solution {
    public boolean canJump(int[] nums) {
        int jumpMax = 0;

        for (int i = 0; i < nums.length; ++i) {
            //i在能跳到的范围内,更新跳最远的位置
            if (i <= jumpMax) {
                jumpMax = Math.max(jumpMax, i + nums[i]);
                //大于等于末尾
                if (jumpMax >= nums.length - 1) {
                    return true;
                }
            }
        }
        return false;
    }
}
相关推荐
東隅已逝,桑榆非晚12 小时前
C语言预处理详解:从宏到条件编译
c语言·笔记·算法
cpp_250112 小时前
P10377 [GESP202403 六级] 好斗的牛
数据结构·c++·算法·题解·洛谷·gesp六级
邪修king12 小时前
C++ 红黑树自平衡核心:旋转变色、规则详解与 STL 选型逻辑
数据结构·c++·b树·算法
随意起个昵称14 小时前
线性dp-计数类题目10(ZBRKA)
算法·动态规划
wgc2k14 小时前
Node.js游戏服务器项目移植 3-手撸简单的内存泄露监控
服务器·游戏·node.js
Navigator_Z20 小时前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
云泽8081 天前
C++ 可调用对象通关指南:深度解析 Lambda 表达式、function 包装器与 bind 绑定器
开发语言·c++·算法
wlsh151 天前
Go 迭代器
算法
winlife_1 天前
在 Unity 里用 AI 做游戏:funplay-unity-mcp 从安装到第一次让 AI 改场景
人工智能·游戏·unity·ai编程·claude·mcp
语戚1 天前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·