給出一個以頭節點 head 作爲第一個節點的鏈表。鏈表中的節點分別編號爲:node_1, node_2, node_3, ... 。
每個節點都可能有下一個更大值(next larger value):對於 node_i,如果其 next_larger(node_i) 是 node_j.val,那麼就有 j > i 且 node_j.val > node_i.val,而 j 是可能的選項中最小的那個。如果不存在這樣的 j,那麼下一個更大值爲 0 。
返回整數答案數組 answer,其中 answer[i] = next_larger(node_{i+1}) 。
注意:在下面的示例中,諸如 [2,1,5] 這樣的輸入(不是輸出)是鏈表的序列化表示,其頭節點的值爲 2,第二個節點值爲 1,第三個節點值爲 5 。
示例 1:
輸入:[2,1,5]
輸出:[5,5,0]
示例 2:
輸入:[2,7,4,3,5]
輸出:[7,0,5,5,0]
示例 3:
輸入:[1,7,5,1,9,2,5,1]
輸出:[7,9,9,9,0,5,0,0]
提示:
對於鏈表中的每個節點,1 <= node.val <= 10^9
給定列表的長度在 [0, 10000] 範圍內
題解:單調隊列;
參考代碼:
1 /** 2 * Definition for singly-linked list. 3 * struct ListNode { 4 * int val; 5 * ListNode *next; 6 * ListNode(int x) : val(x), next(NULL) {} 7 * }; 8 */ 9 class Solution { 10 public: 11 vector<int> nextLargerNodes(ListNode* head) 12 { 13 stack<pair<int,int>>s; 14 map<int,int>m; 15 int key=0; 16 vector<int>ans; 17 while(!s.empty())s.pop(); 18 m.clear(); 19 ans.clear(); 20 21 while(head) 22 { 23 while(!s.empty() && s.top().second<head->val) 24 { 25 m[s.top().first]=head->val; 26 s.pop(); 27 } 28 s.push(make_pair(key++,head->val)); 29 head=head->next; 30 } 31 for(int i=0;i<key;i++){ 32 ans.push_back(m[i]); 33 } 34 35 return ans; 36 } 37 };