单调栈 笔记

本文介绍了单调栈作为一种数据结构,用于解决单调递增或递减问题,如查找元素左右相邻的小元素和计算发射站的最大累积价值。通过单调递增栈和递减栈的原理以及两个示例题目展示了其实现方法。
摘要由CSDN通过智能技术生成

简介

单调栈是一个数据结构,它的主要应用是在解决一些单调递增或单调递减的问题。

单调栈的基本思想是:如果一个序列是单调的(例如,递增或递减),那么可以用一个栈来模拟这个序列。栈顶元素始终表示当前序列的最大值或最小值。这样,我们就可以在 O(1) 时间内回答关于序列的一些问题。

具体实现上,单调栈可以有两种:单调递增栈和单调递减栈。

单调递增栈

在入栈时,始终选择当前序列中的最大值。这样,栈顶元素始终表示当前序列的最大值。对于查询“下一个比当前元素大的元素是什么”,直接返回栈顶元素即可。

单调递减栈

在入栈时,始终选择当前序列中的最小值。这样,栈顶元素始终表示当前序列的最小值。对于查询“下一个比当前元素小的元素是什么”,直接返回栈顶元素即可。

例题

找小的数字

给定一个序列,求每个元素左边最近的比它小的元素。

#include<bits/stdc++.h>
using namespace std;
int n,x;
stack<int> a;
int main(){
	scanf("%d",&n);
	for(int i=1;i<=n;i++){
		scanf("%d",&x);
		while(!a.empty()&&a.top()>x){
			a.pop();
		} 
		if(a.empty()){
			printf("-1 ");
		}
		else{
			printf("%d ",a.top());
		}
		a.push(x);
	}
	return 0;
}

发射站

洛谷 P1901 发射站

#include<bits/stdc++.h>
using namespace std;
int n,maxx,ans[1000005],h[1000005],v[1000005];
int main(){
	scanf("%d",&n);
	stack<int>a;
	for(int i=1;i<=n;i++){
		scanf("%d%d",&h[i],&v[i]);
	}
	for(int i=1;i<=n;i++){
		while(!a.empty()&&h[a.top()]<h[i]){
			ans[i]+=v[a.top()];
			a.pop();
		} 
		if(!a.empty()){
			ans[a.top()]+=v[i];
		}
		a.push(i);
	}
	for(int i=1;i<=n;i++){
		maxx=max(maxx,ans[i]);
	}
	printf("%d",maxx);
	return 0;
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值