6-2 顺序栈的应用:表达式括号匹配 (30分)_数据结构实验3_羊卓的杨

6-2 顺序栈的应用:表达式括号匹配 (30分)

本题要求实现一个表达式括号匹配判断函数,输入参数为一个指针型字符串,字符串长度不可超100,括号有( ),[ ],{ }三种形式(输入形式例如:{[(1+2)*3]}-9)。如果匹配成功,则该函数应该返回1,匹配不成功则返回0。

函数接口定义:

int matching(char* exp);
//提示:可以使用string.h中的"strlen()"函数,帮助判断用户输入的表达式的长度

裁判测试程序样例:

#include <iostream>
using namespace std;

#define STACKSIZE 10
typedef char DataType;
typedef struct 
{
    DataType *base; 
    DataType * top;
    int    stacksize;
}SqStack;
//初始化空顺序栈,细节在此不表
int InitStack(SqStack &S);

//判顺序栈空,细节在此不表
int StackEmpty(SqStack S);

//入栈,细节在此不表
int Push(SqStack &S, DataType item);

//出栈,细节在此不表
int Pop(SqStack &S, DataType &item);

//取栈顶,细节在此不表
int GetTop(SqStack S, DataType &item);

//表达式括号匹配判断函数,自定义
int matching(char* exp);

int main() {
    char expr[100];
    //cout << "请输入表达式:";
    cin >> expr;
    char* ex = expr;
    if (matching(ex)) { cout << "匹配成功"; }
    else { cout << "匹配不成功"; };

    return 0;
}

/* 请在这里填写答案 */

输入样例:

{[1+2](3-2)+[3(1+2)]}

输出样例:

匹配成功

答案样例:

int matching(char* exp){
	SqStack S;
	InitStack(S);
	int i = 0;
	char c;
	while(exp[i] != '\0'){
		switch(exp[i]){
			case '(': Push(S, '('); break;//左括号直接入栈 
			case '[': Push(S, '['); break;
			case '{': Push(S, '{'); break;
			case ')': if(StackEmpty(S)) return 0; Pop(S, c); if(c != '(') return 0; break;//右括号检测 
			case ']': if(StackEmpty(S)) return 0; Pop(S, c); if(c != '[') return 0; break;
			case '}': if(StackEmpty(S)) return 0; Pop(S, c); if(c != '{') return 0; break;
			default: break;
		}
		i++;
	}
	if(StackEmpty(S))
		return 1;
	else return 0;
}

我的好伙计你点个赞再走,你要是三连一下就更好了❀,点个赞再走,点个赞再走,点个赞再走

bilibili:羊卓的杨
公众号:羊卓的杨

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值