【贪心算法】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)。

相关推荐
bkspiderx1 小时前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法
纪元A梦6 小时前
贪心算法应用:基因编辑靶点选择问题详解
算法·贪心算法
共享家95278 小时前
优先搜索(DFS)实战
算法·leetcode·深度优先
flashlight_hi9 小时前
LeetCode 分类刷题:2563. 统计公平数对的数目
python·算法·leetcode
楼田莉子10 小时前
C++算法专题学习:栈相关的算法
开发语言·c++·算法·leetcode
dragoooon3410 小时前
[数据结构——lesson3.单链表]
数据结构·c++·leetcode·学习方法
轮到我狗叫了10 小时前
力扣.1054距离相等的条形码力扣767.重构字符串力扣47.全排列II力扣980.不同路径III力扣509.斐波那契数列(记忆化搜索)
java·算法·leetcode
dragoooon3412 小时前
[优选算法专题二滑动窗口——串联所有单词的子串]
数据结构·c++·学习·算法·leetcode·学习方法
刃神太酷啦12 小时前
C++ 异常处理机制:从基础到实践的全面解析----《Hello C++ Wrold!》(20)--(C/C++)
java·c语言·开发语言·c++·qt·算法·leetcode
薰衣草233314 小时前
滑动窗口(2)——不定长
python·算法·leetcode