-
题目描述:
-
输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。
-
输入:
-
每个测试案例包括3行:
第一行为1个整数n(1<=n<=100000),表示序列的长度。
第二行包含n个整数,表示栈的压入顺序。
第三行包含n个整数,表示栈的弹出顺序。
-
输出:
-
对应每个测试案例,如果第二个序列是第一个序列的弹出序列输出Yes,否则输出No
-
c++代码:
//1366
#include<cstdio>
#include<memory.h>
#include<stack>
using namespace std;
const int MAX = 100000+2;
int arr[MAX],brr[MAX];
int
main(void)
{
int n;
while(~scanf("%d", &n))
{
stack<int> stk;
memset(arr,0,sizeof(arr));
for(int i=0; i<n; ++i)
{
scanf("%d", &arr[i]);
}
while(!stk.empty())
{
stk.pop();
}
bool flag;
int j = 0;
for(int i=0; i<n; ++i)
scanf("%d", &brr[i]);
for(int i=0; i<n; ++i)
{
int tmp = brr[i];
flag = false;
if(stk.empty()!=true && stk.top()==tmp)
{
flag = true;
stk.pop();
continue;
}
for(int k=j; k<n; k++)
{
if(arr[k] == tmp)
{
flag = true;
j = k+1;
break;
}
else
stk.push(arr[k]);
}
if(!flag)
break;
}
if(flag)
printf("Yes\n");
else
printf("No\n");
}
return 0;
}