单调栈——发射站

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

 

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

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

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 ++ )
        {
            while(a[i] > p[top].first && top)
            s[i] += b[p[top -- ].second];
        s[p[top].second
单调栈是一种特殊的栈结构,它的主要应用是用于解决求某个元素的左边或右边第一个比它大或小的元素的问题。单调栈的特点是栈中的元素保持有序,即栈顶元素最小或最大。而发射站是一个具体的应用场景,我们可以利用单调栈来解决相关问题。 在一个发射站中,我们需要找到每个位置的第一个比它大的位置。我们可以使用单调栈来实现这个功能。首先,我们将第一个元素的下标入栈。然后,依次遍历剩下的每个元素。对于每个元素,我们将它与栈顶元素进行比较。如果当前元素比栈顶元素大,说明找到了以栈顶元素为高度的发射站,我们可以更新它对应的输出结果,并弹出栈顶元素。直到当前元素小于或等于栈顶元素,我们将当前元素的下标入栈。这样,最后栈中剩下的元素对应的输出结果为-1,表示没有找到比它大的位置。 使用单调栈来解决发射站问题的时间复杂度为O(n),其中n为发射站的个数。这是因为每个元素最多入栈一次,出栈一次,所以遍历所有元素的时间复杂度为O(n)。而每个元素入栈和出栈的操作时间复杂度为O(1)。因此,总的时间复杂度为O(n)。 综上所述,利用单调栈结构可以高效地解决发射站问题。通过遍历发射站中的元素,可以找到每个位置的第一个比它大的位置。这种方法的时间复杂度为O(n),其中n为发射站的个数。因此,使用单调栈是一个有效的解决方案。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值