编号为1,2,…,n的n辆火车依次进站,给定一个n的排 列,判断是否是合法的出站顺序?
思路:先把出站顺序存入,用栈模拟进站的火车,按照出站的顺序,依次pop出来,判断:最后的出站数量能否达到n。
#include<cstdio>
#include<string.h>
#include<stack>
using namespace std;
const int MAXN = 1010;
stack<int> s;
int train[MAXN];
该博客探讨了一个涉及栈的数据结构问题:如何判断给定的火车出站顺序是否合法。通过模拟火车进站过程,使用栈来存储进站火车,并按照出站顺序弹出,检查最终出站数量是否等于总火车数。
编号为1,2,…,n的n辆火车依次进站,给定一个n的排 列,判断是否是合法的出站顺序?
思路:先把出站顺序存入,用栈模拟进站的火车,按照出站的顺序,依次pop出来,判断:最后的出站数量能否达到n。
#include<cstdio>
#include<string.h>
#include<stack>
using namespace std;
const int MAXN = 1010;
stack<int> s;
int train[MAXN];
1613

被折叠的 条评论
为什么被折叠?
