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出栈。结束