单调栈——发射站

该博客讨论了一道利用单调栈解决的编程题目。题目特点是需要比较相邻塔的高度,根据单调性判断吸收能量或破坏栈。解题策略分为两种情况:如果下一座塔高度低,则栈顶塔吸收其能量;若高度高,则需清除栈中所有低于它的塔。文中给出了C++代码实现,使用了``中的`pair`类型,并通过`ios::sync_with_stdio(false)`提高程序运行效率。
摘要由CSDN通过智能技术生成

 

从题目来分析,首先该题目有两个特别的性质,两边最近:多熟悉几次栈同学们就可以有着很明显的感觉,就是这道题要用到简单的数据结构的知识的知识第二个就是比他高,尝试带入单调性,所以显然,这道题考的就是单调栈的知识

运用到单调栈那么这道题就变得清晰了,分为两种情况:

1、如果下一座塔比当前栈顶的塔的高度低,那么当前栈顶就要吸收来的塔的能量

2、如果下一座塔比当前栈顶的塔的高度高,那么就破坏了当前的单调栈,所以一个while循环就要把之前比要来的塔的能量吸收掉

下面是我的代码:

#include <iostream>
#include <utility>

using namespace std;

const int N = 1e6 + 100;
pair<int,int> p[N];
int x,top,ans,n,m,b[N],s[N],a[N];

int main()
{
    ios::sync_with_stdio(false);
    cin >> n;
    for(int i = 1; i <= n; i ++ )
        cin >> a[i] >> b[i];
    p[++ top].first = a[1];
    p[top].second = 1;
    for(int i = 2; i <= n; i &
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值