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

跳跃游戏

给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。

示例 1:

输入 :nums = [2,3,1,1,4]
输出: true
解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。

解题思路

  • 1、数组的最后一个位置开始向前遍历,每次检查当前位置能否跳到目标位置(即数组的最后一个位置)。
  • 2、如果能跳到目标位置,则更新目标位置为当前位置, 继续向前遍历。
  • 3、最后,如果目标位置为数组的第一个位置,则说明可以到达最后一个下标,返回 true;否则,返回 false。

java实现

java 复制代码
public class JumpGame {
    public boolean canJump(int[] nums) {
        int target = nums.length - 1; // 目标位置初始化为数组的最后一个位置

        for (int i = nums.length - 2; i >= 0; i--) { // 从倒数第二个位置向前遍历数组
            if (i + nums[i] >= target) { // 如果当前位置能够跳到目标位置,则更新目标位置为当前位置
                target = i;
            }
        }

        return target == 0; // 如果目标位置为数组的第一个位置,则返回 true;否则,返回 false
    }

    public static void main(String[] args) {
        JumpGame solution = new JumpGame();
        int[] nums1 = {2, 3, 1, 1, 4};
        int[] nums2 = {3, 2, 1, 0, 4};
        System.out.println("Can jump (nums1): " + solution.canJump(nums1)); // Output: true
        System.out.println("Can jump (nums2): " + solution.canJump(nums2)); // Output: false
    }
}

时间空间复杂度

  • 时间复杂度:遍历一次数组,时间复杂度为O(n),其中n为数组nums的长度。

  • 空间复杂度:仅使用了常数级的额外空间,空间复杂度为O(1)。

相关推荐
谈笑也风生2 小时前
只出现一次的数字 II(一)
数据结构·算法·leetcode
aloha_7893 小时前
测试开发工程师面经准备(sxf)
java·python·leetcode·压力测试
im_AMBER3 小时前
Leetcode 47
数据结构·c++·笔记·学习·算法·leetcode
小白程序员成长日记5 小时前
2025.11.06 力扣每日一题
算法·leetcode
7澄16 小时前
深入解析 LeetCode 数组经典问题:删除每行中的最大值与找出峰值
java·开发语言·算法·leetcode·intellij idea
橘颂TA8 小时前
【剑斩OFFER】算法的暴力美学——二分查找
算法·leetcode·面试·职场和发展·c/c++
还是码字踏实9 小时前
基础数据结构之哈希表:两数之和(LeetCode 1 简单题)
数据结构·leetcode·散列表
Kt&Rs9 小时前
11.5 LeetCode 题目汇总与解题思路
数据结构·算法·leetcode
还是码字踏实9 小时前
基础数据结构之数组的前缀和技巧:和为K的子数组(LeetCode 560 中等题)
算法·leetcode·前缀和·哈希字典
py有趣14 小时前
LeetCode算法学习之两数之和 II - 输入有序数组
学习·算法·leetcode