【C++】括号匹配

复制代码
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<queue>
using namespace std;
const int M=1024;

char a[M];

bool match()
{
    queue<char> q;
    int i=0;
    while(a[i]!='\0')
    {
        if(a[i]=='(')
        {
            q.push(a[i]);
        }
        if(a[i]==')')
        {
            if(q.empty())
                return false;
            else
                q.pop();
        }
        i++;
    }
    if(!q.empty())
        return false;
    else
        return true;
}

int main()
{
    memset(a,'\0',sizeof(a));
    while(scanf("%s",a))
    {
        if(match())
            cout<<1<<endl;
        else 
            cout<<0<<endl;
        memset(a,'\0',sizeof(a));
    }
    
    return 0;
}
复制代码

 

经典的简单问题,网上的代码大都是自己实现辅助队列,算法描述并不直观,所以我用了一下STL类库,让代码简洁明了一点。

 

 

 

tz@HZAU

2019/3/15

posted on   tuzhuo  阅读(263)  评论(0编辑  收藏  举报

编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
历史上的今天:
2018-03-15 2016年蓝桥杯省赛A组c++第3题(图论)
2018-03-15 Java的四种内部类(含代码实例)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示