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

2022/1/26 23:34:43

本文主要是介绍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;
} 
一道较为简单的考察数据结构的题目,了解题目含义后就可以使用双端队列或者栈来模拟就可以了,当然推荐肯定是栈 这题也提示套娃的结构之一栈

这篇关于6.6 训练参考(不定期更新,填坑的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程