【算法基础课模板笔记+注释】 数据结构06 --- 单调栈

声明

本文资料参考acwing算法基础课
地址:https://www.acwing.com

概述
  1. 解决问题:依次查找某个数组每一位前第一个满足某条件的数
  2. 遍历到的数既是目标对象,也是被查集合的元素
  3. 比如查找比那个数小的第一个数,则当压入栈的数比栈顶小的时候,栈顶就没有了作用。
模板记忆

这个模板分为两个部分:

  1. :遍历到某个数的时候,通过依次弹出来查找满足条件的数
  2. :新数字压入栈中
模板代码
while (n -- )
{
    int x;
    cin >> x;
    while (top != 0 && st[top - 1] >= x) top --;
    if (top == 0) cout << -1 << ' ';
    else cout << st[top - 1] << ' ';
    st[top ++ ] = x;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值