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

[Leetcode]下一个更大元素II

时间:2019-02-10 17:42:09      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:顺序   tac   while   注意   题目   一个   ext   遍历   开始   

题目

给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素),输出每个元素的下一个更大元素。数字 x 的下一个更大的元素是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一个更大的数。如果不存在,则输出 -1。

示例 1:
输入: [1,2,1]
输出: [2,-1,2]

解释: 
第一个 1 的下一个更大的数是 2;
数字 2 找不到下一个更大的数; 
第二个 1 的下一个最大的数需要循环搜索,结果也是 2。
注意: 输入数组的长度不会超过 10000。

思路:

这道题最简单的思路就是暴力算法了,效率为O(n^2),可以模拟得出。

最开始我一直以为这道题是动态规划题,解了好久,但发现不存在最优子结构这个特性,于是换了一种思路-栈。

建立一个存储下标位置(index)的栈s,我们从nums顺序取出元素,判断这个元素是不是某位数的下一位更大元素。这个判断操作是通过比较取出的这个元素和栈顶元素,细节如下。

  1. 如果取出的元素更大,说明这个元素是栈顶元素的下一个更大元素,将其放在对应的位置并弹出栈顶值,继续与下一个比较(所以要用while进行而不是if)

  2. 如果取出的元素更小或者栈已经为空(无法比较了),说明这个元素不是下一个更大元素或者没有可以比较的元素,则将这个下标压入栈。

其中代码还将循环操作进行了一个优化,由于寻找遍历的元素个数绝对在2n个以内,所以遍历的时候就将2n作为上限。

代码的具体实现:

class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        unsigned len=nums.size();
        vector<int>res(len,-1);
        stack<int>s;
        for(unsigned i=0;i<len*2;i++){
            int num=nums[i%len];
            while(!s.empty()&&nums[s.top()]<num){
                res[s.top()]=num;
                s.pop();
            }
            if(i<len)s.push(i);
            }
        return res;    
    }
        
};

[Leetcode]下一个更大元素II

标签:顺序   tac   while   注意   题目   一个   ext   遍历   开始   

原文地址:https://www.cnblogs.com/adamwong/p/10359444.html

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