第五周项目3-括号的搭配

问题及代码:

/*     
*烟台大学计算机与控制工程学院      
*作    者:  张相如 
*完成日期:2016年10月13日
*问题描述:假设表达式中允许三种括号:圆括号、方括号和大括号。编写一个算法,判断表达式中的各种左括号是否与右括号匹配。   
例如,输入2+(3+4)[2+{[3]}-8,输出匹配正确;输入2+(3+4[2)+{[3]}-8,输出匹配错误。  
提示:(1)遇到左括号入栈,遇到右括号后,出栈一个符号,看是否配对。若配对,继续,直到读完所有的符号,栈也正好为空。若在中间出现一个不配对的,或者____,则可以得出不配对的结论。(2)也可以设计一个返回值为布尔型的函数,参数为要配对的表达式,为一个字符串。  
*/    

sqstack.h:

<pre class="cpp" name="code">#define MaxSize 100    
typedef char ElemType;    
typedef struct    
{    
    ElemType data[MaxSize];    
    int top;                //栈指针    
} SqStack;                  //顺序栈类型定义    
    
void InitStack(SqStack *&s);    //初始化栈    
void DestroyStack(SqStack *&s);  //销毁栈    
bool StackEmpty(SqStack *s);     //栈是否为空    
int StackLength(SqStack *s);  //返回栈中元素个数——栈长度    
bool Push(SqStack *&s,ElemType e); //入栈    
bool Pop(SqStack *&s,ElemType &e); //出栈    
bool GetTop(SqStack *s,ElemType &e); //取栈顶数据元素    
void DispStack(SqStack *s);  //输出栈 

sqstack.cpp:

<pre class="cpp" name="code">#include <stdio.h>    
#include <malloc.h>    
#include "sqstack.h"    
    
void InitStack(SqStack *&s)    
{    
    s=(SqStack *)malloc(sizeof(SqStack));    
    s->top=-1;    
}    
void DestroyStack(SqStack *&s)    
{    
    free(s);    
}    
int StackLength(SqStack *s)  //返回栈中元素个数——栈长度    
{    
    return(s->top+1);    
}    
bool StackEmpty(SqStack *s)    
{    
    return(s->top==-1);    
}    
bool Push(SqStack *&s,ElemType e)    
{    
    if (s->top==MaxSize-1)    //栈满的情况,即栈上溢出    
        return false;    
    s->top++;    
    s->data[s->top]=e;    
    return true;    
}    
bool Pop(SqStack *&s,ElemType &e)    
{    
    if (s->top==-1)     //栈为空的情况,即栈下溢出    
        return false;    
    e=s->data[s->top];    
    s->top--;    
    return true;    
}    
bool GetTop(SqStack *s,ElemType &e)    
{    
    if (s->top==-1)         //栈为空的情况,即栈下溢出    
        return false;    
    e=s->data[s->top];    
    return true;    
}    
    
void DispStack(SqStack *s)  //输出栈    
{    
    int i;    
    for (i=s->top;i>=0;i--)    
        printf("%c ",s->data[i]);    
    printf("\n");    
}    

main.cpp:

<pre class="cpp" name="code">#include <stdio.h>    
#include "sqstack.h"    
int main()    
{    
    char c;    
    char st[50];    
    int d=1, i;    
    SqStack *s;    
    InitStack(s);    
    printf("请输入表达式:");    
    scanf("%s", st);    
    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)    
        printf("配对正确!!\n");    
    else    
        printf("配对错误!!\n");    
    return 0;    
}   
运行结果:

知识点总结:

栈的实际应用问题

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值