免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
_实验报告括号匹配问题、一、实验目的:1、熟练掌握数据结构基本知识;2、通过括号匹配的实验,了解栈的表示和栈的基本操作,掌握栈“后进先出”的特性并能够应用这一特性。二、实验工具:C-Free三、实验内容:设表达式中包含三种括号:圆括号、方括号和花括号,它们可互相嵌套,如( )或( ( ( ) ) )等均为正确格式,而( )、 ( ) 或( 等均不正确。在算法中可设置一个栈,每读入一个括号,若是左括号,则直接入栈,等待相匹配的同类右括号;若读入的是右括号,且与当前栈顶的左括号同类型,则二者匹配将栈顶的左括号出栈,否则属于不合法情况。另外,如果输入序列已读完,而栈中仍有等待匹配的左括号,或者读入了一个右括号,而栈中已无等待匹配的同类型的左括号,均属不合法情况。当输入序列和栈同时为空时,说明所有括号完全匹配。四、实验过程:#include #include #define STACKINCREAMENT 10 #define STACK_INIT_SIZE 100 #define OVERFLOW -2 #define OK 1 #define ERROR 0 typedef int status; typedef char SElemtype; typedef struct SElemtype *base; SElemtype *top; status stacksize; sqstack; status Init(sqstack *s) s-base = (SElemtype *)malloc(STACK_INIT_SIZE * sizeof(SElemtype); if(!s-base) exit(OVERFLOW); s-top = s-base; s-stacksize = STACK_INIT_SIZE ; return OK; status push(sqstack *s, SElemtype e) if(s-top - s-base = s-stacksize) s-base=(SElemtype*)realloc(s-base,(s-stacksize+STACKINCREAMENT)*sizeof(SElemtype) if(!s-base) exit(OVERFLOW); s-top = s-base + s-stacksize; s-stacksize += STACKINCREAMENT; *s-top+ = e; return OK; status pop(sqstack *s, SElemtype *e) if(s-top = s-base) return ERROR; *e=*-s-top; return OK; status stackempty(sqstack *s) if(s-top=s-base) return OK; return ERROR; status Parenthesis_match(sqstack *s,char *str) int i=0, flag=0; SElemtype e; while(stri != 0) switch(stri) case (: push(s,stri); break; case : push(s,stri); break; case ): pop(s,&e); if(e != () flag=1; break; case : pop(s,&e); if(e!=) flag=1; break; default: break; if(flag) break; i+; if(!flag & stackempty(s) printf(括号匹配成功!n); else printf(括号匹配失败!n); return OK; int main() char str100, enter; sqstack s; Init(&s); printf(请输入字符串:n); scanf(%s,str); scanf(%c,&en
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 44807.2-2025集成电路电磁兼容建模第2部分:集成电路电磁干扰特性仿真模型传导发射建模(ICEM-CE)
- 2025年高职人文地理与城乡规划(城市规划设计)试题及答案
- 2025年中职服装设计与工艺(服装缝纫技术)试题及答案
- 2025年高职物流管理(物流成本核算)试题及答案
- 2025年大学大四(哲学)伦理学原理综合测试试题及答案
- 2025年中职石油炼制技术(石油炼制基础)试题及答案
- 2025年中职计算机网络技术(网络安全基础)试题及答案
- 2025年大学大一(物联网工程)物联网导论试题及答案
- 2025年大学三年级(临床医学)内科学阶段测试题及答案
- 2025年中职城市轨道交通(车站运营管理)试题及答案
- 2026年1月福建厦门市集美区后溪镇卫生院补充编外人员招聘16人笔试备考试题及答案解析
- 2026年乡村治理体系现代化试题含答案
- 2026元旦主题班会:马年猜猜乐新春祝福版 教学课件
- 王洪图黄帝内经80课时讲稿
- 个人借条电子版模板
- 新版FMEA(AIAG-VDA)完整版PPT可编辑FMEA课件
- YY/T 0833-2020肢体加压理疗设备通用技术要求
- GB/T 5023.7-2008额定电压450/750 V及以下聚氯乙烯绝缘电缆第7部分:二芯或多芯屏蔽和非屏蔽软电缆
- GB/T 17984-2000麻花钻技术条件
- GB 15196-2015食品安全国家标准食用油脂制品
- 瑜伽师地论(完美排版全一百卷)
评论
0/150
提交评论