单调栈(c++)

干货

先讲讲单调栈

单调栈,就是只有递增或递减的栈。(单调递减栈单调递增栈

给一个数组,让它们进入单调递减栈的规则是:

如果栈为空,直接进入;

如果要进入的数小于等于栈顶的数,则直接进入;

如果要进入的数大于栈顶的数,就删除栈顶的数,重复直到进入的数小于等于栈顶的数,然后进入。

单调递增栈反之。

题目

每日温度

给定一个数 n ,接下来 n 个数,表示每天的温度,返回一个数组 c ,其中 c [ i ] 是指对于第 i 天下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用0来代替。

示例 1:
输入:

8

73 74 75 71 69 72 76 73

输出

1 1 4 2 1 1 0 0

示例 2:
输入

4

30 40 50 60
输出

1 1 1 0

示例 3:
输入:

3

30 60 90
输出:

1 1 0

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
struct aaaaa
{
	int aa,ii;
};
stack<aaaaa> b;
int a[100010];
int c[100010];
int n;
int main()
{
	cin>>n;
	for(int i = 1;i<=n;i++)
	{
		cin>>a[i];
	}
	for(int i = 1;i<=n;i++)
	{
		aaaaa w;
		w.aa = a[i];
		w.ii = i;
		if(b.empty()==true) b.push(w);
		else
		{
			if(w.aa<=b.top().aa) b.push(w);
			else
			{
				while(true)
				{
					if(b.empty()==true||w.aa<=b.top().aa) break;
					c[b.top().ii] = i-b.top().ii;
					b.pop();
				}
				b.push(w);
			}
		}
	}
	
	for(int i = 1;i<=n;i++)
	{
		cout<<c[i]<<" ";
	}
	
	return 0;
}

柱状图中的最大矩形

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
struct aaaaa
{
	int aa,ii;
};
stack<aaaaa> b;
int a[100010];
int n;
int ma,cnt;
int main()
{
	cin>>n;
	for(int i = 1;i<=n;i++)
	{
		cin>>a[i];
	}
	a[++n] = 0;
	for(int i = 1;i<=n;i++)
	{
		aaaaa w;
		w.aa = a[i];
		w.ii = i;
		if(b.empty()==true) b.push(w);
		else
		{
			if(w.aa>=b.top().aa) b.push(w);
			else
			{
				while(true)
				{
					if(b.empty()==true||w.aa>=b.top().aa) break;
					ma = max(ma,(i-b.top().ii)*b.top().aa);
					b.pop();
				}
				b.push(w);
			}
		}
	}
	cout<<ma;
	return 0;
}
相关推荐
AA陈超7 分钟前
虚幻引擎5 GAS开发俯视角RPG游戏 P04-12 可缩放浮点数的曲线表
c++·游戏·ue5·游戏引擎·虚幻
旭意16 分钟前
C++微基础备战蓝桥杯之数组篇10.1
开发语言·c++·蓝桥杯
青草地溪水旁1 小时前
VSCode C/C++ 构建任务配置文件 `tasks.json` 全字段深度解析
c语言·c++·vscode
代码改善世界2 小时前
【C语言操作符终极指南】万字总结:从二进制到表达式求值,全方位解析+避坑指南
c语言
迪丽热爱2 小时前
【练】C程序设计-01程序设计和C语言
c语言·开发语言
爱和冰阔落4 小时前
C++模板进阶 非类型模板参数 模板的特化 分离编译的深入探索
c++·面试·编译原理·模板
charlie11451419110 小时前
精读C++20设计模式:行为型设计模式:中介者模式
c++·学习·设计模式·c++20·中介者模式
楼田莉子10 小时前
Qt开发学习——QtCreator深度介绍/程序运行/开发规范/对象树
开发语言·前端·c++·qt·学习
oioihoii10 小时前
超越 std::unique_ptr:探讨自定义删除器的真正力量
c++
Gohldg10 小时前
C++算法·贪心例题讲解
c++·数学·算法·贪心算法