这两道题本人没有做出来,看了leetcode大佬的思路,把这两道题整理出来放在了一起。
题目描述:
给定一个非负整数数组,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个位置。
从后往前:
我们记录一个的坐标代表当前可达的最后节点,这个坐标初始等于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;
}
}
给定一个非负整数数组,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
你的目标是使用最少的跳跃次数到达数组的最后一个位置。
从后向前搜索:
我们已经知道最终要到达最后一个位置,然后我们只需找到离当前位置的最远节点,然后继续找上上个位置,找到第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;
}