【第五周项目3】括号的匹配

/*
    Copyright (c)2017,烟台大学计算机与控制工程学院        
    All rights reserved.        
    文件名称:16.cpp        
    作    者:尚文哲     
    完成日期:2017年10月11日        
        
            
    问题描述:假设表达式中允许三种括号:圆括号、方括号和大括号。编写一个算法,判断表达式中的各种左括号是否与右括号匹配。   
              例如,输入2+(3+4)*[2+{[3]}]-8,输出匹配正确;输入2+(3+4*[2)+{[3]}-8,输出匹配错误。  
    输入描述:输入表达式  
    程序输出:输出判断结果  
*/
      
      
    //(1)头文件:  
      
    #include<stdio.h>    
    #include<malloc.h>    
    typedef char ElemType;    
    typedef struct linknode    
    {    
        ElemType data;              //数据域    
        struct linknode *next;      //指针域    
    } LiStack;                      //链栈类型定义    
        
        
    void InitStack(LiStack *&s);  //初始化栈    
    void DestroyStack(LiStack *&s);  //销毁栈    
    int StackLength(LiStack *s);  //返回栈长度    
    bool StackEmpty(LiStack *s);  //判断栈是否为空    
    void Push(LiStack *&s,ElemType e);  //入栈    
    bool Pop(LiStack *&s,ElemType &e);  //出栈    
    bool GetTop(LiStack *s,ElemType &e);  //取栈顶元素    
    void DispStack(LiStack *s);  //输出栈中元素    
      
      
    //(2)源文件:  
      
      
     #include"head.h"    
    void InitStack(LiStack *&s)    
    {    
        s=(LiStack *)malloc(sizeof(LiStack));    
        s->next=NULL;    
    }    
        
        
    void DestroyStack(LiStack *&s)    
    {    
        free(s);    
    }    
    int StackLength(LiStack *s)    
    {    
        int i=0;    
        s=s->next;    
        while(s!=NULL)    
        {    
            i++;    
            s=s->next;    
        }    
        return i;    
    }    
    bool StackEmpty(LiStack *s)    
    {    
        if(s->next==NULL)    
        {    
            return true;    
        }    
        else return false;    
    }    
    void Push(LiStack *&s,ElemType e)    
    {    
        LiStack *l;    
        l=(LiStack *)malloc(sizeof(LiStack));    
        l->data=e;    
        l->next=s->next;    
        s->next=l;    
    }    
    bool Pop(LiStack *&s,ElemType &e)    
    {    
        LiStack *l;    
        l=s;    
        if(l->next==NULL)    
        {    
            return false;    
        }    
        l=s->next;    
        e=l->data;    
        s->next=l->next;    
        free(l);    
        return true;    
    }    
    bool GetTop(LiStack *s,ElemType &e)    
    {    
        if(s->next==NULL)    
        {    
            return false;    
        }    
        e=s->next->data;    
        return true;    
    }    
    void DispStack(LiStack *s)    
    {    
        LiStack *l;    
        l=s;    
        l=l->next;    
        while(l!=NULL)    
        {    
            printf("%c",l->data);    
            l=l->next;    
        }    
        printf("\n");    
     
    }    
      
    //(3)main函数:  
      
    #include "sqstack.h"    
        
    bool isMatch(char *st)    
    {    
        int d=1, i;    
        char c;    
        SqStack *s;    
        InitStack(s);    
        for(i=0; st[i]!='\0'&&d; i++)    
        {    
            switch(st[i])    
            {    
            case'(':    
            case'[':    
            case'{':    
                Push(s, st[i]);    
                break;    
            case')':    
                Pop(s, c);    
                if(c!='(') d=0;    
                break;    
            case']':    
                Pop(s, c);    
                if(c!='[') d=0;    
                break;    
            case'}':    
                Pop(s,c);    
                if(c!='{') d=0;    
                break;    
            }    
        }    
        if(StackEmpty(s)&&d==1)    
            return true;    
        else    
            return false;    
    }    
        
    int main()    
    {    
        
        char st[50];    
        printf("请输入表达式:");    
        scanf("%s", st);    
        if(isMatch(st))    
            printf("配对正确!!\n");    
        else    
            printf("配对错误!!\n");    
        return 0;    
    }    


运行结果:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值