C题单调栈

C题单调栈O(n)

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
    int n;
    cin >> n;
    vector<ll> a(n),b(n);
    for (ll &e : a) cin >> e;
    stack<int> stk;
    for (int i = 0;i < n; ++i)
    {
        while(!stk.empty() && a[stk.top()] < a[i])
        {
            b[stk.top()] = i + 1;
            stk.pop();
        }
        stk.push(i);
    }
    for(ll e : b) cout << e << " ";
    cout << endl;
    return 0;
}
全部评论

相关推荐

点赞 评论 收藏
分享
06-26 17:24
已编辑
宁波大学 golang
迷失西雅图:别给,纯kpi,别问我为什么知道
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务