LeetCode 45. Jump Game II
Posted StackAnalyzer
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 45. Jump Game II相关的知识,希望对你有一定的参考价值。
Given an array of non-negative integers, you are initially positioned at the first index of the array.
Each element in the array represents your maximum jump length at that position.
Your goal is to reach the last index in the minimum number of jumps.
For example:
Given array A = [2,3,1,1,4]
The minimum number of jumps to reach the last index is 2
. (Jump 1
step from index 0 to 1, then 3
steps to the last index.)
Note:
You can assume that you can always reach the last index.
如果从后往前想,即用递归的思想来思考,会得到比较差的算法,时间复杂度会达到O(n^2)
如果从前往后想,就会想到时间复杂度为O(n)的算法
这里采用的是O(n)的空间复杂度,还可以继续优化到O(1)的空间复杂度
1 int d[1000000]={0}; 2 int jump(int* nums, int numsSize) { 3 if(numsSize==1)return 0; 4 int hasNumPlace=0; 5 int endPlace=0; 6 for(int i=0;i<numsSize-1;i++){ 7 if(i+nums[i]>numsSize-1) //out of nums range 8 endPlace=numsSize-1; 9 else 10 endPlace=i+nums[i]; 11 12 for(int j=hasNumPlace+1;j<=endPlace;j++){ 13 d[j]=d[i]+1; 14 } 15 16 if(hasNumPlace<i+nums[i]) 17 hasNumPlace=i+nums[i]; 18 if(hasNumPlace==numsSize-1) 19 break; 20 } 21 return d[numsSize-1]; 22 }
以上是关于LeetCode 45. Jump Game II的主要内容,如果未能解决你的问题,请参考以下文章
[LeetCode] 45. Jump Game II Java
19.2.7 [LeetCode 45] Jump Game II