-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
Copy path_1019.java
66 lines (59 loc) · 1.98 KB
/
_1019.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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package com.fishercoder.solutions;
import com.fishercoder.common.classes.ListNode;
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
public class _1019 {
public static class Solution1 {
public int[] nextLargerNodes(ListNode head) {
int len = findLength(head);
int[] result = new int[len];
ListNode tmp = head;
int i = 0;
while (tmp != null) {
result[i++] = findNextLarger(tmp.val, tmp);
tmp = tmp.next;
}
return result;
}
private int findNextLarger(int val, ListNode head) {
ListNode tmp = head.next;
while (tmp != null) {
if (tmp.val > val) {
return tmp.val;
}
tmp = tmp.next;
}
return 0;
}
private int findLength(ListNode head) {
ListNode tmp = head;
int count = 0;
while (tmp != null) {
tmp = tmp.next;
count++;
}
return count;
}
}
public static class Solution2 {
// Store the nodes of linked list into an array list
// Create a stack that stores indexes, which would be needed to find the next greater element of
// element at index i
public int[] nextLargerNodes(ListNode head) {
List<Integer> numList = new ArrayList<>();
for (ListNode temp = head; temp != null; temp = temp.next) {
numList.add(temp.val);
}
Stack<Integer> stack = new Stack<>();
int result[] = new int[numList.size()];
for (int i = 0; i < numList.size(); i++) {
while (!stack.isEmpty() && numList.get(stack.peek()) < numList.get(i)) {
result[stack.pop()] = numList.get(i);
}
stack.push(i);
}
return result;
}
}
}