蓝桥杯-百亿富翁

题意:n个点,求出每个点的左边,右边,第一个比他高的点。

思路:单调栈。

void solve(){
    int n;
    cin >> n;

    vector<int> a(n);
    for (auto&x : a){
        cin >> x;
    }

    stack<int> stk;
    vector<pair<int, int>> ans(n, {-1, -1});
    stk.push(0);
    for (int i = 1; i < n; ++i){
        while (!stk.empty() && a[stk.top()] <= a[i]){
            stk.pop();
        }
        if (!stk.empty()){
            ans[i].first = stk.top() + 1;
        }
        stk.push(i);
    }
    while (!stk.empty()){
        stk.pop();
    }
    stk.push(n - 1);

    for (int i = n - 2; i >= 0; --i){
        while (!stk.empty() && a[stk.top()] <= a[i]){
            stk.pop();
        }
        if (!stk.empty()){
            ans[i].second = stk.top() + 1;
        }
        stk.push(i);
    }

    for (int i = 0; i < n; ++i){
        cout << ans[i].first << " \n"[i == n - 1];
    }
    for (int i = 0; i < n; ++i){
        cout << ans[i].second << " \n"[i == n - 1];
    }
}

总结:为什么stack没有clear呢?

posted @   _Yxc  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示