-
-
Notifications
You must be signed in to change notification settings - Fork 291
Expand file tree
/
Copy path376.java
More file actions
43 lines (43 loc) · 1.48 KB
/
376.java
File metadata and controls
43 lines (43 loc) · 1.48 KB
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
__________________________________________________________________________________________________
sample 0 ms submission
public class Solution {
public int wiggleMaxLength(int[] nums) {
if (nums.length < 2)
return nums.length;
int down = 1, up = 1;
for (int i = 1; i < nums.length; i++) {
if (nums[i] > nums[i - 1])
up = down + 1;
else if (nums[i] < nums[i - 1])
down = up + 1;
}
return Math.max(down, up);
}
}
__________________________________________________________________________________________________
sample 32900 kb submission
class Solution {
public int wiggleMaxLength(int[] nums) {
if (null == nums || 0 == nums.length) {
return 0;
}
int max = 1;
int[] up = new int[nums.length];
int[] down = new int[nums.length];
Arrays.fill(up, 1);
Arrays.fill(down, 1);
for (int i = 1; i < nums.length; i++) {
for (int j = 0; j < i; j++) {
if (nums[i] > nums[j]) {
up[i] = Math.max(up[i - 1], down[j] + 1);
} else if (nums[i] < nums[j]) {
down[i] = Math.max(down[i - 1], up[j] + 1);
}
}
max = Math.max(max, up[i]);
max = Math.max(max, down[i]);
}
return max;
}
}
__________________________________________________________________________________________________