码迷,mamicode.com
首页 > 其他好文 > 详细

[栈] leetcode 1019 Next Greater Node In Linked List

时间:2019-08-11 17:22:44      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:下标索引   cond   i++   单调栈   link   div   def   push   gre   

problem:https://leetcode.com/problems/next-greater-node-in-linked-list/

        维护递减的单调栈。这道题对象是链表,不像数组可以快速通过下标索引,所以比较方便的做法是在栈中同时记录数字和对应的下标,并且默认填0,如果找到了比它大的第一个数,再修改下标对应的数字。

/**
 * 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) {
        stack<pair<int,int>> sta;
        vector<int> res;
        int i = 0;
        ListNode* cur = head;
        while(cur)
        {
            while(!sta.empty() && cur->val > sta.top().first)
            {
                int idx = sta.top().second;
                sta.pop();
                res[idx] = cur->val;
            }
            sta.push({ cur->val, i++});
            res.push_back(0);
            cur = cur->next;
        }
        
        return res;
    }
};

 

[栈] leetcode 1019 Next Greater Node In Linked List

标签:下标索引   cond   i++   单调栈   link   div   def   push   gre   

原文地址:https://www.cnblogs.com/fish1996/p/11335303.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!