基本作用
求数组中,每个数左边(右边)第一个大于(小于)他的数。
TIP
- 左边还是右边?for从1到n自然是求左边第一个大于(小于)他的数,后边的数压根没输入,肯定没法求。当然,for从n到1自然是求右边第一个大于(小于)他的数。
- 大于还是小于?如果求第一个大于他的数,那么把他push进栈之前,必然下边都是大于他的数,也就是push之前,清空栈里小于等于他的数。
1. 单调栈(模板)
/*
* Author: Chen_zhuozhuo
* Created Time: 2020/7/29 6:24:08
* File Name: c.cpp
*/
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <string>
#include <vector>
#include <stack>
#include <queue>
#include <set>
#include <time.h>
#define rep(i,a,b) for(int i=(a);i<=(b);i++)
#define per(i,a,b) for(int i=(a);i>=(b);i--)
#define debug(x) cout << #x << ": " << x << endl
using namespace std;
typedef long long ll;
typedef pair<int,int> PII;
const int maxint = -1u>>1;
const int inf = 0x3f3f3f3f;
const int maxn = 1e5 + 10