forked from keineahnung2345/leetcode-cpp-practices
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1019. Next Greater Node In Linked List.cpp
38 lines (35 loc) · 1.3 KB
/
1019. Next Greater Node In Linked List.cpp
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
//Hint 1: We can use a stack that stores nodes in monotone decreasing order of value. When we see a node_j with a larger value, every node_i in the stack has next_larger(node_i) = node_j .
//Runtime: 208 ms, faster than 84.96% of C++ online submissions for Next Greater Node In Linked List.
//Memory Usage: 25.5 MB, less than 58.82% of C++ online submissions for Next Greater Node In Linked List.
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
vector<int> nextLargerNodes(ListNode* head) {
ListNode* cur = head;
vector<int> inputs;
while(cur){
inputs.push_back(cur->val);
cur = cur->next;
}
vector<int> ans(inputs.size(), 0);
stack<int> stk;
for(int i = 0; i < inputs.size(); i++){
//stk's elements are in decreasing order
//pop all elements <= inputs[i] and set their corresponding ans
//the other elements remains in the stack
while(!stk.empty() && inputs[i] > inputs[stk.top()]){
ans[stk.top()] = inputs[i];
stk.pop();
}
stk.push(i);
}
return ans;
}
};