首页 > 代码库 > 栈之括号匹配

栈之括号匹配

输入:
3
[(])
(])
([[]()])
样例输出
No
No
Yes

#include<cstdio>
#include<cstring>
char str[1010];
char stack[1010];
int main()
{
	int T;
	while(~scanf("%d",&T)) 
	{
		while(T--)
		{
			scanf("%s",str);
			int top=1;
			stack[top++]=str[0];
			for(int i=1;i<strlen(str);i++)
			{
				if(str[i]==']' && stack[top-1]=='[')
				     top--;
				else if(str[i]==')' && stack[top-1]=='(')
				     top--;
				else
				     stack[top++]=str[i];
			}
			  printf( top==1 ? "Yes\n" : "No\n");
		}
	}
	return 0;
} 

栈之括号匹配