2454. 下一个更大元素 IV

题目描述

给你一个下标从 0开始的非负整数数组 nums。对于 nums中每一个整数,你必须找到对应元素的 第二大 整数。

如果 nums[j]满足以下条件,那么我们称它为 nums[i]的 第二大 整数:

  • j > i
  • nums[j] > nums[i]
  • 恰好存在 一个 k满足 i < k < jnums[k] > nums[i]。如果不存在 nums[j],那么第二大整数为 -1
  • 比方说,数组 [1, 2, 4, 3]中,1的第二大整数是 42的第二大整数是 334的第二大整数是 -1

请你返回一个整数数组 answer,其中 answer[i]是 nums[i] 的第二大整数。

做题情况

  1. 做出来且思路与标答一致
  2. 做出来但思路较为复杂 ☑
  3. 有思路,但时间复杂度较高无法通过
  4. 没有思路

自己的想法:

其实自己的思想路线是完全正确的,最后结果也没有什么问题,就是中间有个地方想的不太对。另外之后自己可以多用纸和笔来去梳理,感觉只去想害挺容易出错的。

标答:单调栈+优先队列

这个题目的基础是找到比当前点第一个大的元素,这里相当于是一种扩展,当然我们可以在简单模式的思路上进行延申。对于那些弹出的,他们只找到了比自己大的第一个数,所以还需要找比自己大的下一个数,因此用一个结构来进行储存,等待下一个来的数。
至于用什么结构来进行储存,优先队列肯定是可以的,因为时间允许nlogn的复杂度。这里插一句,对于pair的优先队列,是先排second,再排first。

除此之外就还是栈了。这个地方自己想错了。
因为如果新来一个元素时,我们现在第二个栈进行扫描,再在第一个栈进行扫描,所以第二个栈中剩下的一定是比新加的这一批要大的。
如果是讨论扫描的那一批,由于在栈1中一定是降序排列的,所以如果逐个加入到下一个栈中,这些一定是升序的,这于其他批之间的顺序不是很明晰。因此我们可以将一批的反转一下加入到栈中去,这样整个栈同样是递减的,我们可以按照对栈1的那样操作来进行。

实际代码

class Solution {
public:
    vector<int> secondGreaterElement(vector<int>& nums)
    {
        stack<pair<int, int>> sta1;
        priority_queue<pair<int, int>> que;
        vector<int>res(nums.size(), -1);
        for (int i = 0; i < nums.size(); ++i)
        {
            if (sta1.empty()) sta1.push(make_pair(i, nums[i]));
            else
            {
                while (!que.empty() && que.top().second < nums[i])
                {
                    cerr << que.top().second << endl;
                    res[que.top().first] = nums[i];
                    que.pop();
                }
                while (!sta1.empty() && sta1.top().second < nums[i])
                {
                    que.push(sta1.top());
                    sta1.pop();
                }
                sta1.push(make_pair(i, nums[i]));
            }
        }
        return res;
    }
};

总结

总的来说这个题的处理自己还是比较满意的,希望自己再接再厉!不过后面的大小顺序自己没有想清楚,这个地方可以再进步一下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值