数据结构实验三:栈表示与实现(括号匹配问题)

实验内容:假设表达式中允许包含圆括号、方括号和大括号3种括号,编写一个算法判断表达式中的括号是否正确配对。并将其用C语言实现,上机运行输出结果。用顺序栈实现。提示:输入一串包括左右圆、方、大括号的字符,则左括号入栈,当和右括号匹配时,则出栈。

实验分析:这次的实验不难,主要的就是对顺序表的一种特殊的操作形式,需要注意的就是思考清楚出栈的控制条件与结束时的控制语句,因此我们要先在顺序栈中压入一个‘#’来作为入栈出栈的结束控制符。

源代码:

头文件与定义语句

#include<iostream>
using namespace std;
#define	maxsize 100
typedef struct{//定义顺序栈 
	char *top;
	char *base;
	int stacksize;
}sqstack;

动态分配,为顺序栈分配相应的静态空间:

void initstack(sqstack &s){//创建顺序栈分配空间 
	s.base=new char[maxsize];
	if(!s.base)	cout<<"创建顺序栈失败!"<<endl;
	else{
		s.top=s.base;
		s.stacksize=maxsize;
		cout<<"创建顺序栈成功!"<<endl;
	}
}

子函数,主要实现入栈,出栈,匹配的相应操作

void push(sqstack &s,char e){//入栈操作 
	if(s.top-s.base==s.stacksize)	cout<<"栈已满!"<<endl;
	else *s.top++=e;
}
char out(sqstack s){//出栈操作 
	if(s.top!=s.base)	return*(s.top-1);
} 
int contrast(sqstack &s,char e){
	if(e==')'&&out(s)=='('){
		s.top=s.top-1;
		return 1;
	}
	else if(e=='}'&&out(s)=='{'){
		s.top=s.top-1;
		return 1;
	}
	else if(e==']'&&out(s)=='['){
		s.top=s.top-1;
		return 1;
	}
	else return 0;
} 

主函数:

int main(){
	sqstack s;
	int temp,flag=0;
	char e;
	initstack(s);
	push(s,'#');
	cout<<"请输入一串英文括号并以#结尾:"<<endl;
	cin>>e;
	if(e==*s.base||(e!='('&&e!='{'&&e!='[')){
		cout<<"请输入正确格式的括号!"<<endl;
		return 0;
	}
	else push(s,e);
	while(e!=*s.base){
		cin>>e;
		if(e=='('||e=='{'||e=='[')	push(s,e);
		else if(e==')'||e=='}'||e==']')	{
			temp=contrast(s,e);
			if(!temp){
				cout<<"括号匹配失败!"<<endl;
				flag=0;
				return 0; 
			}
			else	flag=1;
		}
		else if(e=='#'){
			break;
		}
		else{
			cout<<"请输入正确格式的括号!"<<endl;
			return 0;
		}
	}
	
	if(s.top-s.base!=1)	cout<<"括号匹配失败!"<<endl;
	else if(e='#'&&flag==1)	cout<<"括号匹配成功!"<<endl;
}

注意子符串判断的条件,可能会忽略了一些情况导致结果不完全准确!

实验结果:

注:尤其要注意“()(#”这一类的以左括号结尾的符号串,如果显示配对成功,那你要仔细看看你的判断语句是否少判断了条件!

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值