链栈c语言实现括号匹配,链栈实现括号匹配.cpp

/***链栈实现括号匹配***/

#include

using namespace std;

#define OK 1

#define ERROR 0

#define OVERFLOW -2

typedef char SElemType;

typedef int Status;

typedef struct SNode {

int data;

struct SNode *next;

} SNode, *LinkStack;

Status InitStack(LinkStack &S) {

S = NULL;

return OK;

}

bool StackEmpty(LinkStack S) {

if (!S)

return true;

return false;

}

Status Push(LinkStack &S, SElemType e) {

SNode *p = new SNode;

if (!p) {

return OVERFLOW;

}

p->data = e;

p->next = S;

S = p;

return OK;

}

Status Pop(LinkStack &S, SElemType &e) {

SNode *p;

if (!S)

return ERROR;

e = S->data;

p = S;

S = S->next;

delete p;

return OK;

}

Status GetTop(LinkStack &S) {

if (!S)

return ERROR;

return S->data;

}

//算法3.21 括号的匹配

Status Matching() {//检验表达式中所含括号是否正确匹配,如果匹配,则返回true,否则返回false

//表达式以“#”结束

char ch;

SElemType x;

LinkStack S;

InitStack(S); //初始化空栈

int flag = 1; //标记匹配结果以控制循环及返回结果

cin >> ch; //读入第一个字符

while (ch != '#' && flag) //假设表达式以“#”结尾

{

switch (ch) {

case '[' :

case '(': //若是左括号,则将其压入栈

Push(S, ch);

break;

case ')': //若是“)”,则根据当前栈顶元素的值分情况考虑

if (!StackEmpty(S) && GetTop(S) == '(')

Pop(S, x); //若栈非空且栈顶元素是“(”,则正确匹配

else

flag = 0; //若栈空或栈顶元素不是“(”,则错误失败

break;

case ']': //若是“]”,则根据当前栈顶元素的值分情况考虑

if (!StackEmpty(S) && GetTop(S) == '[')

Pop(S, x); //若栈非空且栈顶元素是“[”,则正确匹配

else

flag = 0; //若栈空或栈顶元素不是“[”,则错误匹配

break;

} //switch

cin >> ch; //继续读入下一个字符

} //while

if (StackEmpty(S) && flag)

return true; //匹配成功

else

return false; //匹配失败

}

int main() {

LinkStack S;

cout << "请输入待匹配的表达式,以“#”结束:" << endl;

int flag = (int) Matching();

if (flag)

cout << "括号匹配成功!" << endl;

else

cout << "括号匹配失败!" << endl;

return 0;

}

一键复制

编辑

Web IDE

原始数据

按行查看

历史

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值