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

相关推荐
.Vcoistnt1 小时前
Codeforces Round 1024 (Div. 2)(A-D)
数据结构·c++·算法·贪心算法·动态规划·图论
是代码侠呀3 小时前
从前端视角看网络协议的演进
leetcode·开源·github·github star·github 加星
刃神太酷啦5 小时前
类和对象(1)--《Hello C++ Wrold!》(3)--(C/C++)
java·c语言·c++·git·算法·leetcode·github
I AM_SUN6 小时前
994. 腐烂的橘子
数据结构·c++·算法·leetcode·职场和发展
Tisfy7 小时前
LeetCode 3341.到达最后一个房间的最少时间 I:Dijkstra算法(类似深搜)-简短清晰的话描述
leetcode··最短路·dijkstra·题解·迪杰斯特拉
朱剑君16 小时前
第四天——贪心算法——种花
算法·贪心算法
纪元A梦17 小时前
贪心算法应用:顶点覆盖问题详解
java·算法·贪心算法
_Itachi__19 小时前
LeetCode 热题 100 543. 二叉树的直径
java·算法·leetcode
Tisfy1 天前
LeetCode 1550.存在连续三个奇数的数组:遍历
算法·leetcode·题解·数组·遍历
wang__123001 天前
力扣70题解
算法·leetcode·职场和发展