括号匹配问题

有四种情况
  • 左右括号匹配,如:({}[])
  • 左括号多出,如:([())
  • 右括号多出,如:(()])
  • 括号顺序不匹配,如:[(])
用栈实现思路如下
  • 当遇到左括号的时候入栈
  • 当遇到右括号的时候,与栈顶的左括号匹配,栈顶左括号出栈;若不匹配,则匹配失败
  • 若栈以空,还有未匹配的右括号,说明右括号多出,匹配失败
  • 括号匹配完成后,若栈未空,说明左括号多出,匹配失败
  • 以上情况都未出现,匹配成功
代码如下
#include<stdio.h>
#define STACKMAX 100
#define STACKADD 10

int StackEmpty(SqStack* S);//若栈为空返回1,否则返回0
char GetTop(SqStack* S);//若栈不为空,保存栈顶的元素并返回1;否则返回0
int Push(SqStack* S,char e);//插入栈顶元素
int PopStack(SqStack* S);//若栈不为空,则删除栈顶元素并返回1,否则返回0

int StackEmpty(SqStack* S)
{
    if(S->base == S->top)
        return 1;
    return 0;
}

char GetTop(SqStack* S)
{
    if(StackEmpty(S))
        return 0;
    return *(S->top-1);
}

int Push(SqStack* S,datatype e)
{
    if(S->top - S->base >= S->stacksize)
    {
        S->base = (datatype*)realloc(S->base,
        (S->stacksize+STACKADD)*sizeof(datatype));
        if(!S->base)
            return 0;
        S->top = S->base + S->stacksize;
        S->stacksize += STACKADD;
    }
    *S->top++ = e;
    return 1;
}

int PopStack(SqStack* S)
{
    if(StackEmpty(S))
        return 0;
    --S->top;
    return 1;
}

int CheckBraceStack(char *str)//不匹配返回0,匹配返回1
{
    SqStack S;
    int i,flag,len;
    len = strlen(str);
    flag = 1;
    InitStack(&S);
    for(i=0; i<len; i++)
    {
        if(str[i]=='(' || str[i]=='{' || str[i]=='[')
            Push(&S,str[i]);
        else if(str[i] == ')')
        {
            if(GetTop(&S) == '(')
                PopStack(&S);
            else
                flag = 0;
        }
        else if(str[i] == '}')
        {
            if(GetTop(&S) == '{')
                PopStack(&S);
            else
                flag = 0;
        }
        else if(str[i] == ']')
        {
            if(GetTop(&S) == '[')
                PopStack(&S);
            else
                flag = 0;
        }
    }
    if(!StackEmpty(&S))
        flag = 0;
    return flag;
}

int main()
{
    char str[10086];
    printf("Enter brackets:");
    scanf("%s",str);
    if(CheckBraceBreak(str))
        printf("ok\n");
    else
        printf("bu ok\n");
    return 0;
}
测试结果如下

这里写图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值