数据结构实验之栈与队列四:括号匹配 SDUT-2134

数据结构实验之栈与队列四:括号匹配

题目描述:

给你一串字符,不超过50个字符,可能包括括号、数字、字母、标点符号、空格,你的任务是检查这一串字符中的( ) ,[ ],{ }是否匹配。


Input
输入数据有多组,处理到文件结束。


Output
如果匹配就输出“yes”,不匹配输出“no”


Sample Input

sin(20+10)
{[}]


Sample Output

yes
no


题解:

对左括号入栈,然后遇到右括号,就和栈内的括号进行匹配,若匹配,则出栈。
出现第一个不匹配的情况的时候,则结束循环。
最后需要判断是否把字符串的每一个字符都走一遍循环,若走完,且栈为空,输出 “yes”,否则输出 “no”。

AC代码:

#include <bits/stdc++.h>

using namespace std;

char s[60];
char sta[60];
int main()
{
    while(gets(s))
    {
        int top=0;
        int i;
        int l=strlen(s);
        for(i = 0;i < l;i++)
        {
            if(s[i]=='('||s[i]=='['||s[i]=='{'){
                sta[top]=s[i];
                top++;
            }
            else if(s[i]==')'||s[i]==']'||s[i]=='}')
            {
                if(s[i]==sta[top-1]+1||s[i]==sta[top-1]+2)
                {
                    top--;
                }
                else
                {
                    break;
                }
            }
        }
        if(i == l&& !top)
            cout<<"yes"<<endl;
        else
            cout<<"no"<<endl;
    }
    return 0;
}


原题链接:山理工2134

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

PythonXQ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值