Problem 55: Jump Game
思路
dynamic programming 的思路在判断大的数据的时候超时,这时用 greedy programming
像头标枪一样,我不关心最后我是否到最后一个index了,先闷头扔一下,一直维护到最后一次,然后比较我最后所在的位置和数组最后一个的位置之间的关系
Update: 这个解法更容易理解。用 max 来记录当前最远能调到的距离,如果 i < max,说明无论如何也打不到,返回 false。
易错点
dp的做法
这个做法的时间复杂度是O(n^2),当数据过大时,会超过时间要求
判断的条件
这两个条件是缺一不可的。如果没有第一个条件,有可能是i很大,已经超过了farest
比较条件
开始的时候,错误地
这里我们要比的是farest最后的index,而nums[n - 1]表示的是最后还能再跳几个值。他们是明显不同的。
Last updated