-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCanJumpSolution.java
46 lines (44 loc) · 1.17 KB
/
CanJumpSolution.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
public class CanJumpSolution {
/**
* @param A: A list of integers
* @return: The boolean answer
*/
public static boolean canJump(int[] A) {
// wirte your code here
int i = 0;
while(i < A.length){
if(A[i] == 0){
return false;
}
if(A[i] < A.length - 1 - i){
i = findMax(A, i);
System.out.println(i);
}
else{
return true;
}
}
return true;
}
private static int findMax(int[] A , int i){
int j = i;
int res = i;
int max = A[i] + i;
while(j <= i + A[i]){
if(max <= A[j] + j){
max = A[j] + j;
res = j;
}
//max = max > (A[j] + j) ? max : (A[j] + j);
j++;
}
return res;
}
public static void main(String args[]){
//int[] A = {-3,1,1,-3,5};
//ArrayList<Integer> A = new ArrayList<Integer>();
//Integer a = new Integer(1);
int[] A ={2,1,0,2,3,2,8,5,7,10,9,9,6,6,3,4,2,9,9,0};
System.out.println(canJump(A));
}
}