专栏文章

题解:AT_abc394_d [ABC394D] Colorful Bracket Sequence

AT_abc394_d题解参与者 1已保存评论 0

文章操作

快速查看文章及其快照的属性,并进行相关操作。

当前评论
0 条
当前快照
1 份
快照标识符
@miq5k8kq
此快照首次捕获于
2025/12/03 23:19
3 个月前
此快照最后确认于
2025/12/03 23:19
3 个月前
查看原文
彩色括号序列就是所有括号都能配对的序列。
我们用一个栈来维护配对情况:
  • 遇到一个左括号或者栈是空的就进栈。
  • 遇到一个右括号就判断栈顶能不能和它配对,如果能就弹出。
如果最后栈为空就说明配对成功。

Code

CPP
#include<bits/stdc++.h>
using namespace std;
string s;
int n;
stack<char> st;
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0);cout.tie(0);
	cin>>s;n=s.size();s=" "+s;
	for(int i=1;i<=n;i++){
		if(st.empty()||s[i]=='('||s[i]=='['||s[i]=='<')st.push(s[i]);
		else if(st.top()=='('&&s[i]==')')st.pop();
		else if(st.top()=='['&&s[i]==']')st.pop();
		else if(st.top()=='<'&&s[i]=='>')st.pop();
		else st.push(s[i]);
	}
	if(!st.empty())cout<<"No";
	else cout<<"Yes";
	return 0;
}

评论

0 条评论,欢迎与作者交流。

正在加载评论...