SCAU 18715 出栈序列

SCAU 18715 出栈序列

因为是小白所以要用小白的方法解决
在这里插入图片描述
看到题目后的思路:
1.栈为空时,入栈
2.若栈顶元素比将要入栈的元素小,将将要入栈的元素入栈(用数组存);反之,将栈顶元素出栈,直到遇到比将要入栈的元素小的。(使用循环)
3.当i>=n时结束若栈中还有元素,则不停出栈。
4.然后,就没有然后了

#include<stdio.h>
#include<stack>
using namespace std;
const int N=1000005;
int a[N];
int main()
{
    int n,i,j,k,ma;//ma用来存栈顶元素
   stack<int> S;//初定义栈S
    scanf("%d",&n);
    for(i=1; i<=n; i++)
    {
        scanf("%d",a+i);//就是数组了
    }
    i=1;
    while( !S.empty() || i<=n )//如果栈不为空或者i<n,两者满足一即可
    {
        if( S.empty() )
            S.push(a[i++]);//头元素入栈,或者i<n时,但栈还是空时入栈
        else//栈不为空时
        {
            ma = S.top();//ma去栈顶元素
            k = 0;//相当于标记一连串中要入栈的元素的位置
            for(j=i; j<=n; j++)
            {
                if(ma < a[j])//如果栈顶元素小于要入栈的元素
                    ma = a[j],k = j;//栈顶元素变为a[j]相当于把它当成栈顶元素
                    //k标记到这一串中最后一个满足入栈条件的元素的位置
            }
            if(k!=0)
            {
                for(j=i; j<=k; j++)//j从i的位置开始,到后一个满足入栈条件的元素的位置,将所有这些元素入栈
                    S.push(a[j]);
                i = k+1;//找出还有什么元素未入栈
            }
            printf( "%d ",S.top());
            S.pop();
        }
    }
}

例子:
5
1 2 4 5 3
5 4 3 2 1
第一步:输入元素个数n;
第二步:输入数组元素;
第三步:进入循环,若栈为空,将首元素1进栈后,此时i=2;
第四步:i<=n满足,进入循环,栈不为空,栈顶元素ma=1;
此时j=2,ma<a[j]满足,k=2,j=3,ma=2;
栈顶元素ma=2, 此时j=3,ma<a[j]满足,k=3,j=4,ma=4;
栈顶元素ma=4, 此时j=4,ma<a[j]满足,k=4,j=5,ma=5;
栈顶元素ma=5, 此时j=5,ma<a[j]不满足,不做处理。
第五步:k!=0,j将2 4 5入栈
第六步:前面条件都不满足,先将5 4出栈,但还没到停止条件,所以,再进循环,3满足条件,可进栈,后i>n,将3 2 1出栈。结束

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值