求用c语言编写一个表达式中开,闭括号是否合法配对的算法的程序.,编写一个判断算术表达式中开开括号和闭括号是否配对的算法...

891bf370b78668157ef15191393fab26.png

/*本程序实现对表达式括号匹配情况的判断*/

#include "iostream"

using namespace std;

#define MAX 20//表达式的最大长度

int top=1;//栈的顶部指针

void Push(char *&stack,char temp)//压栈操作

{

stack[top]=temp;

top++;

}

void Pop(char *&stack,char &temp)//出栈操作

{

top--;

temp=stack[top];

}

int JudgeMatch(char *&stack,char *BDS)//判断括号匹配函数,是则返回1,不是则返回0

{

int len=strlen(BDS);//表达式长度

char temp='0';//作出栈临时储存变量

for (int i=0;i

{

if(BDS[i]=='('||BDS[i]==')')

{

int flag=0;

if(BDS[i]=='(') flag=1;

switch(flag)//注意表达式括号的各种情况

{

case 1: {Push(stack,BDS[i]);break;}

case 0:

{

Pop(stack,temp);

if(temp=='(')

{

Pop(stack,temp);

if(temp=='0') return 1;

else

Push(stack,temp);

}

else return 0;

}

}

}

}

Pop(stack,temp);

if(temp=='(') return 0;

return 1;

}

int main()

{

FILE *fp;

if (fp=fopen("input4.txt","r"))

{

int num=0;

fscanf(fp,"%d",&num);

for (int i=0;i

{

char Bds[MAX];

fscanf(fp,"%s",Bds);

char *p=Bds;

char stack[MAX]={'0'};

char *sp=stack;

int JVar=JudgeMatch(sp,p);

cout<

}

fclose(fp);

}

return 0;

}

◆◆

评论读取中....

请登录后再发表评论!

◆◆

修改失败,请稍后尝试

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值