Leetcode 刷题笔记----45.55. 跳跃游戏(贪心)

这两道题本人没有做出来,看了leetcode大佬的思路,把这两道题整理出来放在了一起。

题目描述:

55.跳跃游戏

给定一个非负整数数组,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个位置。

从后往前:

我们记录一个的坐标代表当前可达的最后节点,这个坐标初始等于nums.length-1,
然后我们每判断完是否可达,都向前移动这个坐标,直到遍历结束。

如果这个坐标等于0,那么认为可达,否则不可达。

代码:

class Solution {
    public boolean canJump(int[] nums) {
        
        if (nums == null) {
            return false;
        }
        int lastPosition = nums.length - 1;
        for (int i = nums.length - 1; i >= 0; i--) {
            // 逐步向前递推
            if (nums[i] + i >= lastPosition) {
                lastPosition = i;
            }
        }
        return lastPosition == 0;
    }
}

45.跳跃游戏二

给定一个非负整数数组,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

从后向前搜索:

我们已经知道最终要到达最后一个位置,然后我们只需找到离当前位置的最远节点,然后继续找上上个位置,找到第0个就结束了

至于离它最远的位置,其实我们从左到右遍历数组,第一个满足的位置就是我们要找的。

public int jump(int[] nums) {
    int position = nums.length - 1; //要找的位置
    int steps = 0;
    while (position != 0) { //是否到了第 0 个位置
        for (int i = 0; i < position; i++) {
            if (nums[i] >= position - i) {
                position = i; //更新要找的位置
                steps++;
                break;
            }
        }
    }
    return steps;
}

 

 

你可能感兴趣的:(LeetCode-贪心)