UVA 673 Parentheses Balance (栈)

题意描述:

给出一段只包含()和[]的字符串,判断是否合法,合法输出YES,不合法输出NO

规则:

1、该串为空,则合法

2、若A合法,B合法,则AB合法

3、若A合法,则(A)和[A]均合法

解题思路:

括号匹配问题,使用栈来解决,需要注意的是用gets来读取,当该串为空时,输出YES

代码实现:

 1 #include<stdio.h>
 2 #include<string.h>
 3 int f(char a[],int l);
 4 
 5 int main()
 6 {
 7     char a[151];
 8     int T;
 9     
10     scanf("%d",&T);
11     getchar();
12     while(T--)
13     {
14         gets(a);
15         int l=strlen(a);
16         if(l==0 || f(a,l))//
17         printf("Yes\n");
18         else
19         printf("No\n");
20     }
21     return 0;
22 } 
23 
24 int f(char a[],int l)
25 {
26     char s[151];
27     int i,top=0;
28     for(i=0;i<l;i++)
29     {
30         s[top++]=a[i];
31         if(s[top-1]==')' && s[top-2]=='(')    
32             top-=2;
33         if(s[top-1]==']' && s[top-2]=='[')
34             top-=2;
35     }
36     if(top==0)
37     return 1;
38     else
39     return 0;
40 }

易错分析:

注意读题,根据题目来写

 

转载于:https://www.cnblogs.com/wenzhixin/p/8343968.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值