【19. 单调栈】

简介: 单调栈**用途**:主要找到每个数左边离他最近的且比它小的数在什么地方(或者找到每个数右边离他最近的且比它大的数在什么地方)

单调栈

用途:主要找到每个数左边离他最近的且比它小的数在什么地方(或者找到每个数右边离他最近的且比它大的数在什么地方)

题目

给定一个长度为 N 的整数数列,输出每个数左边第一个比它小的数,如果不存在则输出 −1。

输入格式

第一行包含整数 N,表示数列长度。

第二行包含 N 个整数,表示整数数列。

输出格式

共一行,包含 N 个整数,其中第 i 个数表示第 i 个数的左边第一个比它小的数,如果不存在则输出 −1。

数据范围

1≤ N ≤ 105
1≤ 数列中元素 ≤ 109

输入样例:

5
3 4 2 7 5

输出样例:

-1 3 -1 2 2

方法一:暴力解法

for (int i = 0; i < n; i ++)
    for (int j = i - 1; j >= 0; j --)
        if (a[i] > a[j])
        {
            cout << a[j] << endl;
            break;
        }
#include <iostream>
using namespace std;
const int N = 100010;
int q[N];
int n;

int main()
{
    cin >> n;
    for (int i = 0; i < n; i ++)  cin >> q[i];
    
    for (int i = 0; i < n; i ++)
    {
        int j = i - 1;
        for (; j >= 0; j --)
        {
            if (q[j] < q[i])
            {
                cout << q[j]<<" ";
                break;
            }
             
        }
        if (j < 0)
       {
         cout << "-1" <<" ";
       }
    }
    return 0;
}

方法二:优化

  • 用栈存储 i 左边的元素
  • 如果 ax >= ay,并且x < y那么ax永远不会输出,就直接可以删除。(只要有这种逆序的关系,前面的数就会被删掉,此时剩下的序列就是单调序列了)
#include <iostream>
using namespace std;
const int N = 100010;
int n;
int stk[N], tt;

int main()
{
    cin >> n;
    for (int i = 0; i < n; i ++)
    {
        int x;
        cin >> x;
        while (tt && stk[tt] >= x) tt -- ;
        if (tt) cout << stk[tt] << " ";
        else cout << "-1" << " ";
        stk[ ++ tt] = x;
        //cout << tt << endl;;
    }
    return 0;
}
目录
相关文章
|
2天前
|
存储 算法 搜索推荐
探索常见数据结构:数组、链表、栈、队列、树和图
探索常见数据结构:数组、链表、栈、队列、树和图
76 64
|
10天前
|
算法 安全 测试技术
golang 栈数据结构的实现和应用
本文详细介绍了“栈”这一数据结构的特点,并用Golang实现栈。栈是一种FILO(First In Last Out,即先进后出或后进先出)的数据结构。文章展示了如何用slice和链表来实现栈,并通过golang benchmark测试了二者的性能差异。此外,还提供了几个使用栈结构解决的实际算法问题示例,如有效的括号匹配等。
golang 栈数据结构的实现和应用
|
2天前
|
Go
数据结构之 - 深入了解栈数据结构
数据结构之 - 深入了解栈数据结构
11 5
|
11天前
01_设计一个有getMin功能的栈
01_设计一个有getMin功能的栈
|
11天前
|
前端开发
07_用队列实现栈
07_用队列实现栈
|
11天前
06_用栈来求解汉诺塔问题
06_用栈来求解汉诺塔问题
|
11天前
05_用一个栈实现另一个栈的排序
05_用一个栈实现另一个栈的排序
|
11天前
03_如何仅用递归函数和栈操作逆序一个栈
03_如何仅用递归函数和栈操作逆序一个栈
|
11天前
|
测试技术
02_由两个栈组成的队列
02_由两个栈组成的队列
|
2天前
|
存储
【初阶数据结构】深入解析栈:探索底层逻辑
【初阶数据结构】深入解析栈:探索底层逻辑