时间限制:5000ms
单点时限:1000ms
内存限制:256MB
描述
输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)
输入
第一行:输入N个整数,空格隔开,按先后顺序入栈
第二行:输入N个整数,空格隔开,表示一种出栈顺序
输出
True 或者 False ,意思是第二行数据是否是一个合法的弹出序列
样例输入
1 2 3 4 5 4 5 3 2 1
样例输出
True
解题思路:同上道题,代码可以直接拿来用。只是输入数据没有指定n,我脑袋好像锈了只能先这么处理了。。
AC代码:
#include<stdio.h>
#include<stack>
using namespace std;
stack<int> s;
int a[1020],in[510],out[510];
int main()
{
int cnt=0,x;
while(~scanf("%d",&x))
{
a[cnt++]=x;
}
if(cnt%2!=0||cnt==0) {printf("False\n");return 0;}
for(int i=0;i<cnt/2;i++)
{
in[i]=a[i];
}
for(int i=cnt/2,j=0;i<cnt;i++,j++)
{
out[j]=a[i];
}
int j=0;
for(int i=0;i<cnt/2;i++)
{
s.push(in[i]);
while(!s.empty()&&s.top()==out[j])
{
j++;
s.pop();
}
}
if(j==cnt/2) printf("True\n");
else printf("False\n");
return 0;
}