括号配对问题--nyoj-2(栈)
括号配对问题
时间限制:3000 ms | 内存限制:65535 KB
难度:3
描述现在,有一行括号序列,请你检查这行括号是否配对。
- 输入
- 第一行输入一个数N(0<N<=100),表示有N组测试数据。后面的N行输入多组输入数据,每组输入数据都是一个字符串S(S的长度小于10000,且S不是空串),测试数据组数少于5组。数据保证S中只含有"[","]","(",")"四种字符
- 输出
- 每组输入数据的输出占一行,如果该字符串中所含的括号是配对的,则输出Yes,如果不配对则输出No
- 样例输入
-
3 [(]) (]) ([[]()])
- 样例输出
-
No No Yes
第一次我是用的数组然后遍历搜索,要考虑很多种情况,今天二师兄给我们讲了栈,感觉萌萌哒! -
1 #include<stdio.h> 2 #include<string.h> 3 char stack[10001],a[100001];//以后数组尽量定义到函数外 4 int main() 5 { 6 int n,i,j; 7 scanf("%d",&n); 8 getchar();吸收回车符 9 while(n--) 10 { 11 gets(a); 12 int top=1; 13 stack[0]=a[0]; 14 for(i=1;i<strlen(a);i++) 15 { 16 stack[top]=a[i]; 17 if(stack[top-1]=='['&&stack[top]==']') 18 top--; 19 else if(stack[top-1]=='('&&stack[top]==')') 20 top--; 21 else 22 top++; 23 } 24 if(top==0) 25 printf("Yes\n"); 26 else 27 printf("No\n"); 28 } 29 return 0; 30 }