《C数据结构》括号匹配实验报告

合集下载

括号匹配实验报告书

括号匹配实验报告书

1.实验题目括号匹配的检验;2.需求分析本演示程序用VC++6.0编写,完成圆括号、方括号和大括号,其嵌套的顺序随意,即(()[ ])或{([ ] [ ])}等为正确格式,[[ )]或((()均为不正确的格式。

①输入形式:直接输入一串括号;②输出形式:直接输出输入的括号串是否匹配的结果;③程序所能达到的功能:可以多次输入括号串并判断其是否匹配;④测试数据:输入([ ]()),结果“匹配”输入 [( [)],结果“此串括号匹配不合法”3.概要设计1)为了实现上述程序功能,需要定义栈的抽象数据类型:class Stack{数据对象:kh={ai|ai∈count,i=0,1,2,…,n,n≥0}数据关系:基本操作:push(char b)操作结果:把一个数据压进栈pop()操作结果:把一个数据弹出栈pp(char c[])初始条件:栈已存在操作结果:将栈中的元素进行匹配jc()初始条件:栈已存在操作结果:检查栈是否为空若空,返回0;若不空,返回1.clear()操作结果:清空栈2)本程序包含7个函数:①主函数main()②栈的构造函数Stack()③压栈操作函数push(char b)④弹栈操作函数pop()⑤匹配元素函数pp(char c[])⑥检查栈操作函数jc()⑦清空栈操作函数clear()各函数间关系如下:4.详细设计#include<iostream>#include<string>using namespace std;const int maxstack=100;//-------------------------------------------------------------------class Stack{//栈类public:Stack(){count=-1;};//初始化计数conutvoid push(char b);//压栈char pop();//弹栈void pp(char c[]);//匹配括号int jc();//检查是否为空栈void clear(){count=-1;}private:int count;//计数char a[maxstack];//存储};void Stack::push(char b)//压栈函数{if(count>=maxstack);else{count++;a[count]=b;}}char Stack::pop()//弹栈函数{if(count<0);else{return a[count--];}return 0;}int Stack::jc()//检查函数{if(count<0)return 0;return 1;}void Stack::pp(char c[])//匹配函数{int i=0,s=1,t;t=strlen(c);//测试输入的字符串长度if(c[0]==')'||c[0]==']'||c[0]=='}'||t%2==1)//判断是否为奇个括号或第一个为左括号{cout<<"此串括号匹配不合法"<<"\n"<<endl;}else //判断{while(c[i]!='\0'){if(c[i]=='('||c[i]=='['||c[i]=='{'){push(c[i]);}else{if(c[i]==')'){if(pop()!='('){s=0;break;}}if(c[i]==']'){if(pop()!='['){s=0;break;}}if(c[i]=='}'){if(pop()!='{'){s=0;break;}}}i++;}if(s==1){ if(!jc())cout<<"匹配"<<"\n"<<endl;else cout<<"此串括号匹配不合法"<<"\n"<<endl;}if(s==0)cout<<"此串括号匹配不合法"<<"\n"<<endl;}}//-------------------------------------------------------------------int main(){char a[maxstack];//数组Stack kh;//栈对象char h;cout<<"**************************"<<endl;cout<<"*** 括号匹配测试程序 ***"<<endl;cout<<"**************************"<<endl<<endl;do{cout<<"请输入您的选择: 1.运行程序; 2.结束。

数据结构中关于括号匹配问题的算法

数据结构中关于括号匹配问题的算法

《数据结构》实验报告二实验内容:括号匹配学号:姓名:一、上机实验的问题和要求(需求分析):[ 题目] 假设表达式中允许有两种括号:圆括号和方括号,其嵌套的顺序随意,即(()[ ])或[([ ] [ ])] 等为正确格式,[(])或(((]均为不正确的格式。

读入含圆括号和方括号的符号序列,输出“匹配”或“此串括号匹配不合法”。

二、程序设计的基本思想,原理和算法描述:本程序是在实现栈的基本操作的基础上实现其基本应用,即括号匹配问题,重点利用其“先进后出”的特性三、调试和运行程序过程中产生的问题及采取的措施:(略)四、源程序及注释[ 源程序] 程序名: 4.cpp#include "stdio.h"#include "malloc.h"#include "process.h"#define stack_int_size 8#define stackincrement 10#define overflow -2#define error 0#define ok 1typedef int status;typedef char selemtype;typedef struct{ selemtype * base;selemtype * top;int stacksize;}sqstack;status initstack(sqstack &s){//构造一个空栈ss.base=(selemtype *)malloc(stack_int_size * sizeof(selemtype));if(!s.base)exit(overflow);s.top=s.base;s.stacksize=stack_int_size;return ok;}//initstackstatus emptystack(sqstack s){if(s.top==s.base)return ok;else return error;}status push(sqstack &s,selemtype e){//插入元素e为新的栈顶元素int stacksize;if(s.top-s.base>=s.stacksize){s.base=(selemtype *)realloc(s.base, (s.stacksize+stackincrement )* sizeof(selemtype));if(!s.base)exit (overflow);s.top=s.base+s.stacksize;s.stacksize+=stackincrement;}*s.top++=e;return ok;}//pushstatus pop(sqstack &s,selemtype &e){//若栈不为空,则删除s的栈顶元素,用e返回其值if(s.top==s.base)return error;e=* --s.top;return ok;}//popint kuohao(char m[]){ //若括号匹配则返回1,否则返回0;sqstack s;int i=0;char x;initstack(s);while(m[i]!='#'){ if(m[i]=='('||m[i]=='[')push(s,m[i]);if(m[i]==')'||m[i]==']'){ if(emptystack(s))return 0;else{pop(s,x);if((x=='('&&m[i]==']')||(x=='['&&m[i]==')'))return 0; } }i++;}if(emptystack(s))return 1;else return 0;}void main (){ char e[7]={'(','(','(',']',')',']','#'};int p;p=kuohao(e);printf("说明:若括号匹配的话,输出结果为1,反之则为0.\n");printf("判断结果为:%d\n",p); }五、运行结果如输入的括号序列为:'(','(','(',']',')',']','#'运行结果:0(表明括号不匹配)。

数据结构试验8括号匹配

数据结构试验8括号匹配

问题描述:编写一程序判断从键盘输入的子符串括号是否匹配。

假设需判断的括号只有“(”,“)”,“[”,“]”四种。

#include <stdio.h>#include <malloc.h>#define OK 1#define ERROR 0//定义顺序堆栈#define STACK_SIZE 100 //存储空间初始分配量#define STACK_INC 10 //存储空间分配增量/*typedef char Elem;*/typedef struct{char *base; //栈底指针char *top; //栈顶指针int size; //当前已分配的存储空间}SqStack;/*typedef int Status;*///创建空堆栈,栈顶指针和栈底指针相等时,栈为空int CreatStack(SqStack &S){S.base=(char *)malloc(STACK_SIZE*sizeof(char));S.top=S.base;S.size=STACK_SIZE;return OK;}//堆栈是否为空int StackEmpty(SqStack S){if(S.top!=S.base) return ERROR;return OK;}//进栈int Push(SqStack &S,char e){if(S.top-S.base>=S.size){ //栈满,追加存储空间S.base=(char *)realloc(S.base,(S.size+STACK_INC)*sizeof(char));S.top=S.base+S.size;S.size+=STACK_INC;}*S.top=e;S.top+=1;return OK;}//出栈int Pop(SqStack &S,char &e){if(S.top==S.base) return ERROR;S.top-=1;e=*S.top;return OK;}//括号匹配int Bracket(SqStack &S,char *str){int i=0,flag1=0,flag2;char e;while(str[i]!='\0'){switch(str[i]){case '(':Push(S,'(');break; //'('进栈case '[':Push(S,'[');break; //'['进栈case ')':{Pop(S,e);if(e!='(') flag1=1; break;} //出栈,判断是否为'(' case ']':{Pop(S,e);if(e!='[') flag1=1;break;} //出栈,判断是否为'[' default: break;}if(flag1) break; //出现不匹配,立即结束循环i++;}flag2=StackEmpty(S); //flag2判断堆栈是否为空if(!flag1 && flag2) printf("括号匹配!\n");else printf("括号不匹配!\n");return OK;}//主函数void main(){char temp,flag='y';while(flag=='y'){char str[255];SqStack S;printf("请输入字符串:");scanf("%s",str);scanf("%c",&temp); //接受输入的回车键CreatStack(S);Bracket(S,str);printf("你想再试一次吗(按y继续): ");scanf("%c",&flag);printf("\n");}printf("程序结束.\n");}。

数据结构实验 表达式括号匹配配对判断问题.

数据结构实验 表达式括号匹配配对判断问题.

实验表达式括号匹配配对判断问题姓名:班级:学号:实验时间:1.问题描述一个算术表达式含圆括号、中括号、花括号,且它们可任意嵌套使用。

写一程序,判断任一算术表达式中所含括号是否正确配对。

2.数据结构设计匹配判别发生在右括号出现时,且被匹配的左括号应是距离右括号最近被输入的,二不是最先被输入的括号,即“先入后匹配”。

因此用栈来解决。

#define stacksize 100 //定义栈的空间大小structstack{ //定义栈的结构体char strstack[stacksize];//定义栈的存储格式为字符型 int top; //定义栈的栈顶变量};void InitStack(stack &s){//定义一个新栈s,初始化栈顶为-1s.top = -1;}3.算法设计(1)入栈的算法char Push(stack &s, char a){ //入栈操作,将字符a入栈sif(s.top == stacksize - 1) //当栈顶为栈的空间大小-1,栈满 return 0;s.top ++;//入栈操作一次,栈顶+1s.strstack[s.top] = a;//此时,栈顶元素为字符areturn a;}(2)出栈的算法设计char Pop(stack &s ){ //出栈操作if(s.top == -1) //当栈顶为-1时,栈空return 0;char a = s.strstack[s.top];//将栈顶元素赋予字符a,并返回字符a,完成出栈操作s.top--;return a;}(3)判断栈是否为空的函数int Empty(stack &s,int re){ //定义判断栈是否为空的函数if(s.top==-1)return 1;//栈为空时返回值为1elsereturn 0;//栈不为空时返回值为0}(4)判断是否匹配的算法。

如果右括号,进栈,取下个字符;如果是左括号,出栈,取下个字符;最后判断栈是否为空。

编写一个括号匹配的检验的程序实习报告

编写一个括号匹配的检验的程序实习报告

编写一个括号匹配的检验的程序实习报告在计算机科学领域,括号匹配是一个常见的问题。

括号匹配指的是在一个字符串中,所有的括号都必须正确地成对出现。

如果所有的括号都能正确地匹配,那么该字符串是合法的;否则,该字符串是非法的。

在本次程序实习中,我设计并实现了一个括号匹配的检验程序。

首先,我对括号匹配的问题进行了深入的研究和分析。

我发现,括号匹配问题可以通过使用栈来解决。

栈是一种遵循后进先出原则的数据结构,在括号匹配问题中非常适用。

我使用了一个栈来存储左括号,并在遍历字符串时进行匹配操作。

接下来,我实现了一个简单而高效的括号匹配检验程序。

该程序可以接收一个字符串作为输入,并判断该字符串中的括号是否匹配。

我使用了编程语言(例如C++或Python)来实现该程序,具体的实现细节如下:1. 首先,我创建了一个空栈,用来存储左括号。

2. 然后,我遍历输入的字符串,逐个检查每个字符。

3. 如果当前字符是左括号(例如'('、'{'或'['),则将其推入栈中。

4. 如果当前字符是右括号(例如')'、'}'或']'),则检查栈是否为空。

如果栈为空,则字符串中的右括号没有相应的左括号,该字符串是非法的;如果栈不为空,则将栈顶的左括号弹出并与当前的右括号进行匹配。

如果两个括号不匹配,那么该字符串是非法的。

5. 最后,当遍历完整个字符串后,检查栈是否为空。

如果栈为空,则说明所有的左括号都有相应的右括号,该字符串是合法的;如果栈不为空,则说明字符串中存在未匹配的左括号,该字符串是非法的。

通过实现这个括号匹配的检验程序,我学到了许多关于栈的知识和算法设计的技巧。

此外,我也加深了对括号匹配问题的理解和掌握。

通过编写和调试这个程序,我提高了自己的编程能力和解决问题的能力。

总的来说,本次括号匹配的检验程序实习让我深入了解了括号匹配问题,并通过实际动手编写代码来解决这个问题。

括号配对问题实验报告(3篇)

括号配对问题实验报告(3篇)

第1篇一、实验目的本研究旨在探讨括号配对问题(Balanced Parentheses Problem)的解决策略,分析不同背景知识、认知风格和问题解决经验对括号配对问题解决的影响,以期为相关教学和实践提供参考。

二、实验背景括号配对问题是一种典型的逻辑推理问题,主要考察个体对括号结构的理解和运用能力。

在计算机科学、数学、逻辑学等领域中,括号配对问题具有广泛的应用。

然而,由于括号配对问题的复杂性,许多人难以在短时间内解决此类问题。

因此,研究括号配对问题的解决策略具有重要的理论意义和实际应用价值。

三、实验方法1. 实验对象:选取60名大学生作为实验对象,随机分为三组,每组20人。

其中,A组为计算机科学专业学生,B组为数学专业学生,C组为非计算机及数学专业学生。

2. 实验材料:设计50道括号配对问题,分为易、中、难三个难度级别,每级各15道题。

3. 实验步骤:(1)对实验对象进行分组;(2)对实验对象进行括号配对问题解决能力测试,包括易、中、难三个难度级别的题目;(3)收集实验数据,分析不同背景知识、认知风格和问题解决经验对括号配对问题解决的影响。

四、实验结果与分析1. 不同背景知识对括号配对问题解决的影响A组学生在易、中、难三个难度级别的括号配对问题解决中均优于B组和C组。

这说明计算机科学专业学生在括号配对问题解决方面具有明显优势。

2. 认知风格对括号配对问题解决的影响在易、中、难三个难度级别的括号配对问题解决中,A组和B组学生的直觉型认知风格与逻辑型认知风格无明显差异。

然而,C组学生的直觉型认知风格在易、中、难三个难度级别的括号配对问题解决中均低于逻辑型认知风格。

3. 问题解决经验对括号配对问题解决的影响A组和B组学生在易、中、难三个难度级别的括号配对问题解决中均优于C组。

这说明问题解决经验在括号配对问题解决中具有重要作用。

五、结论与建议1. 结论(1)括号配对问题解决能力与个体背景知识、认知风格和问题解决经验密切相关;(2)计算机科学专业学生在括号配对问题解决方面具有明显优势;(3)问题解决经验在括号配对问题解决中具有重要作用。

实验三实验报告括号匹配的检验

实验三实验报告括号匹配的检验

实验三实验报告括号匹配的检验实验题⽬:括号匹配的检验⼀、实验⽬的加深理解栈的定义和特性;掌握栈的存储结构与实现⼆、实验内容:任意输⼊⼀个由若⼲个圆括号、⽅括号和花括号组成字符串,设计⼀个算法判断该串中的括号是否配对。

三、设计与编码1、基本思想基本思想:最内层(最迟出现)的左刮号必须与最内层(最早出现)的同类右刮号配对,它最急切地期待着配对。

配对之后, 期待得以消解。

因此为左刮号设置⼀个栈,置于栈顶的左刮号期待配对的急切程度最⾼。

实例:[ ( [ ] { } ) ]、( [ { } ] )、{ [ ] } )、( { [ ] }、( { [ ] ] )2、编码#include#includeconst int StackSize=100;class SeqStack{public:SeqStack(){top=-1;}~SeqStack(){}void Push(char s);char Pop();void Peidui(char s[StackSize]);private:char data[StackSize];int top;};void SeqStack::Push(char s){if(top==StackSize-1) throw"上溢";top++;data[top]=s;char SeqStack::Pop(){if(top==-1)throw"下溢";else{char a;a=data[top--];return a;}}void SeqStack::Peidui(char *s){int i=0,l=strlen(s);char t;for(i=0;i{if(s[i]=='{'||s[i]=='['||s[i]=='(')Push(s[i]);else{if(top==-1){cout<<"右括号多了,不匹配"<return;}else{t=data[top];if(t=='{'&&s[i]=='}'||t=='['&&s[i]==']'||t=='('&&s[i]==')') {Pop();}elsebreak;}}if(top==-1&&s[i]=='\0')cout <<"配对成功"<elseif(top!=-1&&s[i]=='\0')cout<<"左括号多了,不匹配"<elsecout<<"左右类型不匹配"<}void main(){char str[10];cout<<"请输⼊括号;"<cin>>str;SeqStack S;S.Peidui(str);}四、调试与运⾏1、调试时遇到的主要问题及解决2、运⾏结果(输⼊及输出,可以截取运⾏窗体的界⾯)五、实验⼼得。

C语言实验二、括号匹配

C语言实验二、括号匹配

实验二、括号匹配一、问题描述假设一个输入字符串中包含圆括号、方括号和花括号三种类型的括号,以及其它一些任意字符。

编写程序,判别串中的括号是否正确匹配,即必须满足以下条件1.各种左、右括号的个数要一致;2.要符合正确的嵌套规则。

基本方法:在算法中设置一个栈,每读入一个括号,若是右括号,则或者使置于栈顶的最后进入的左括号消解,或者是不合法的情况;若是左括号,则压入栈中,同时在算法的开始和结束时,栈都应该为空,否则不合法。

二、基本要求输入一个算术表达式,利用栈存储结构来存入左括号,然后判断表达式中的括号是否匹配。

三、测试数据(1)([3+2]+(7*9))(2)[([3/2 ]-[5*6])](3)[7+8-(8-9])(4)(2+](3*9)))四、实现提示1、算法思路(1)对于栈的操作包括初始化initstack、判断栈是否满sfull、判断栈是否空sempty、入栈push和出栈pop操作。

该函数被主函数调用。

(2)在主函数中输入一个算术表达式,依次取出该算术表达式的某个字符,如果是左括号则入栈,如果是右括号则出栈,并判断右括号与出栈的元素是否匹配。

当算术表达式取完后,再判断栈是否为空,如果不空,则说明括号不匹配。

2、数据结构typedef struct stk//定义的栈结构{char *s; //栈中存放元素int top;//栈顶指针}stack;3、基本操作void initstack(stack *st) /* 栈s1和s2的初始化操作,st为指向s1或s2的指针 */int sfull(stack st) /* 判断栈s1和s2是否满的操作 */int sempty(stack st) /* 判断栈s1和s2是否空的操作 */int push(stack st,char e) /* 入栈操作,e为栈中结点类型 */int pop(stack *st,char *e) /*出栈操作,e为指向栈中结点的指针类型 */5、主程序main(){int i=0;char e;stack s1;//存放左括号的栈char str[100];//存放算术表达式的值initstack(&s1);printf("请输入表达式\n");gets(str);//输入算术表达式while(i<strlen(str)){if (str[i]=='('||str[i]=='['||str[i]=='{'){……}else if (str[i]==')'||str[i]==']'||str[i]=='}'){……else i++;}……}5、输出结果测试数据(1)([3+2]+(7*9))括号匹配(2)[([3/2 ]-[5*6])]括号匹配(3)[7+8-(8-9])第10个元素左右括号不匹配(4)(2+](3*9)))第4个元素左右括号不匹配。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

括号匹配
实验目的:
使用堆栈的存储结构实现括号匹配,即“(”与“)”必须成对出现、“[”与“]”必须成对出现
实验思路:
1、写出堆栈的相关操作函数,如:
创建【int InitStack( SqStack *S )】、
压入【int Push(SqStack *S,int e)】、
弹出【int Pop(SqStack *S,int *e)】、
销毁【void DestroyStack(SqStack *S)】、
判断是否为空【int StackEmpty(SqStack *S)】等。

2、堆栈的各操作函数完成后编写功能函数——括号匹配函数【int
match(char *str)】。

3、括号匹配函数之后编写主函数,使用上述函数实现括号匹配的功能
核心代码:
1、括号匹配函数:
int match(char *str){
int i,e;
SqStack S;
InitStack(&S);
for(i=0;;i++){
if(str[i]=='\0')break;
if(str[i]=='('||str[i]=='['){
Push(&S,str[i]);
};
if(str[i]==')'){
Pop(&S,&e);
if(e=='('){
continue;
}else{
Push(&S,e);
}
}
if(str[i]==']'){
Pop(&S,&e);
if(e=='['){
continue;
}else{
Push(&S,e);
}
}
}
if(StackEmpty(&S)){
printf("恭喜您,括号匹配成功,多项式格式合法!\n");
}else{
printf("警告:多项式格式不合法!\n");
}
DestroyStack(&S);
return 1;
}
2、主函数:
int main(){
char str[100];
printf("请输入一个表达式:");
scanf("%s",&str);
match(str);
system("pause");
return 1;
}
功能演示:
1、输入:(3+45)*[32-5]/[2-5]
输出:恭喜您,括号匹配成功,多项式格式合法!。

相关文档
最新文档