6.6 训练参考(不定期更新,填坑

Parentheses_Balance

点击查看代码
#include<iostream>
#include<stack>
using namespace std;

int main() {
  int T;
  scanf("%d%*c", &T);
  while(T--) {
  	string str;
  	getline(cin, str);
  	bool flag = true;
	stack<char> s;
  	for(int i = 0; i < str.length(); i++) {
  	  if(str[i] == '(') s.push('(');
	  else if(str[i] == '[') s.push('[');
	  else if(str[i] == ')') {
	  	if(!s.empty() && s.top() == '(') s.pop();	
		else{ flag = false; break; }
	  }
	  else if(str[i] == ']') {
	  	if(!s.empty() && s.top() == '[') s.pop();	
		else{ flag = false; break; }
	  }
	}
	if(flag) flag = s.empty();
	if(flag) printf("Yes\n");
	else printf("No\n");
  }
  return 0;
} 
一道较为简单的考察数据结构的题目,了解题目含义后就可以使用双端队列或者栈来模拟就可以了,当然推荐肯定是栈 这题也提示套娃的结构之一栈
上一篇:WPF项目获取代码行数


下一篇:解决 Xshell6|Xftp6 强制升级