实验内容:假设表达式中允许包含圆括号、方括号和大括号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;
}