栈和排序

栈和排序 1.用a数组记录入栈的顺序

2.用maxx数组记录大于等于a[i]且在i后面的数的最大值

3.用一个stack栈s枚举压栈出栈的过程

4.用res数组记录最终的出栈顺序

#include <iostream>
#include <cstring>
#include <algorithm>
#include <vector>
#include <stack>

using namespace std;

int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);
    
    int n;
    cin >> n;
    vector<int> a(n + 10), maxx(n + 10), res;
    
    // 记录入栈的顺序
    for(int i = 0 ; i < n ; i ++ )
        cin >> a[i];
    
    maxx[n - 1] = a[n - 1]; // 比a[n - 1]大的数是他自己
    // 用maxx数组记录大于等于a[i]的数的值
    for(int i = n - 2 ; i >= 0 ; i -- )
        maxx[i] = max(maxx[i + 1], a[i]);

    stack<int> s;
    // 枚举入栈压栈的顺序
    for(int i = 0 ; i < n ; i ++ )
    {
        s.push(a[i]); // 压栈
        
        // 如果栈非空,并且栈顶元素比右边那个的右侧最大值还大的话
        // 说明已经找到剩余序列中的最大值了,即可记录res出栈
        while(s.size() && s.top() >= maxx[i + 1])
        {
            res.push_back(s.top());
            s.pop();
        }
    }
    
    for(int i = 0 ; i < n ; i ++ )
        cout << res[i] << ' ';

    return 0;
}
全部评论

相关推荐

小厂面经,也是我的处女面(30min)1.自我介绍2.spring&nbsp;boot的自动装配原理(好多类和接口的单词都忘了全称是啥了,就说了记得的单词,流程应该说对了吧)3.有用过redis吗?主要是用在实现什么功能(说了技术派用redis的zset来实现排行榜)5.有了解过Redisson吗?讲一下对于分布式锁的了解以及在什么场景下应用(说了秒杀场景)6.对mysql有了解吗?包括它的索引优化和创建(把想起来的全说了)7.了解设计模式吗?比如单例模式,为什么要使用单例模式,它的优点是什么(昨天刚看的设计模式)8.工厂模式有了解吗?主要的使用场景是?(也是昨天刚看的)9.场景题:有7个服务器,需要在早上十点定时的向数据库中的用户表中的用户发短信,如果做到发送的消息不重复,且如果发送失败了需要知道是到哪个用户失败了,这样下次就直接从这个用户开始(我答了用spring&nbsp;task来实现定时,用分布式锁来保证只有一份服务器可以发送消息,用消息队列来存储消息,然后用消息确认机制来保证错误信息的记录,以及在数据库或者业务层面完成消息消费的幂等性)10.场景题:如果在系统启动的时间就将数据库的所有用户相关的信息都读到一个hashmap中(这个没啥思路,没答好)27届的投了一个星期终于有一个面试了,大部分公司都只招26的
inari233:已oc,拒了
查看9道真题和解析
点赞 评论 收藏
分享
03-05 14:55
已编辑
门头沟学院 Java
Jhin4ever:别去,杂活太多,今天让你部署一下模型,明天让你写一下LLM工作流,后天要你研究一下Agent,想微调模型都难
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务