题目是个简单题,但是就是有点问题。
直接模拟就可以,因为给定出栈序列了。当栈顶元素等于出栈数组的头部,就pop。然后判断栈的情况即可。
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <stack>
using namespace std;
const int maxn = 1e5+7;
int a[maxn],b[maxn];
stack<int> stk;
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%d",a+i);
for(int i=1;i<=n;i++) scanf("%d",b+i);
int now = 1;
for(int i=1;i<=n;i++)
{
stk.push(a[i]);
while(stk.top()==b[now])
{
now++;
stk.pop();
if(stk.empty()) break;
}
}
if(stk.empty()) printf("Yes\n");
else printf("No\n");
while(!stk.empty()) stk.pop();
}
return 0;
}