假设以s和x分别表示入栈和出栈操作
合集下载
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
构成的序列,对一个空堆栈进行操作,相应操作均可行(如没有出现删除时栈空)且最后状态也是栈空,则称该序列是合法的堆栈操作序
输入格式:
输入第一行给出两个正整数N和M,其中N是待测序列的个数,M(≤50)是堆栈的最大容量。
随后N行,每行中给出一个仅由S 和X构成的序列。
序列保证不为空,且长度不超过100。
输出格式:
对每个序列,在一行中输出
列,或
输入样例:
4 10
SSSXXSXXSX
SSSXXSXXS
SSSSSSSSSSXSSXXXXXXXXXXX
SSSXXSXXX
结尾无空行
输出样例:
YES
NO
NO
NO
结尾无空行
设计思路:用string存,然后进行操作
#include <iostream>
#include <string>using namespace std;int main() { int a;//栈中的数的数量
int n,m;//其实是n和m
string str;//操作
cin >> n >> m;
getchar();
while (n--) {
a=0;
str.clear(); // 清空字符串getline(cin, str);
for (char i : str) {
if (i== 'S') {
a++;
if (a > m)break;
}
else if (i=='X'){
a--;
if (a<0)break;
}
}
if (a==0){
cout<<"YES"<<endl;
}
else cout<<"NO"<<endl;
}
}。