思路很简单,如果出栈的元素存在于入站的队列中但是该元素不是栈顶元素,那么该出栈队列不可能存在。
#include <iostream> using namespace std; int main() { int num; int n[100]; cin>>num; for(int i=0;;i++){ cin>>n[i]; if(n[i]==0)break; } for(int i=0;i<num-1;i++) {//思路:出站的火车序列顺序要满足的要求是后面的车序号要么大于上一个车,要么比上一个车序号小1. if(n[i]-n[i+1]>1){cout<<"No"; return 0;} } cout<<"Yes"; return 0; }此外,还有栈的方法写代码。
#include <iostream> #include <cstdio> #include <stack> using namespace std; const int MAXN = 1000 + 10; int n, target[MAXN]; int main() { while (scanf("%d", &n) == 1) { stack<int> s; int A = 1,B = 1; for (int i = 1; i <= n; i++) scanf("%d", &target[i]); //输入的出栈顺序 int ok = 1; while (B <= n) { if (A == target[B]) { A++; B++;} //当入栈后又直接出栈的情况 else if (!s.empty() && s.top() == target[B]) { s.pop(); B++;} //当栈顶元素等于出栈顺序元素 else if (A <= n) s.push(A++); //入栈后没有直接出栈 else { ok = 0; break; } } printf("%s\n", ok ? "YES" : "NO"); } return 0; }