


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include#includeTypedef structnodeChar chNode * next Linkstack建立Linkstack *Setstack() /空链堆叠linkstack * S;s=(link stack *)malloc(size of(link stack);s-next=NULL;return S;link stack * push stack(link stack * s,charc) /堆叠linkstack * p;p=(link stack *)malloc(size of(link stack);p-ch=c;p-next=S-next;s-next=p;return S;link stack * pop stack(link stack * s)/堆栈输出linkstack * p;p=S-next;s-next=p-next;自由(p);return S;Char Gettop(Linkstack *S) /获取堆栈顶部数据If(S-next)!=NULL)return S-next-ch;ElseReturn检查Int Judgepair() /括号是否正确配对linkstack * p;char c;int sign=1;p=set stack();Printf(输入算术表达式,并以#结束! n );c=getchar();While(c)!=#)交换机(c)Case(: /扫描目标(堆栈)P=Pushstack(p,c);BreakCase): /扫描目标),堆栈顶部(If (getop (p)=()/堆栈顶部为(,如果堆栈顶部为)p=pop stack(p);如果Else /堆栈顶部不是(),则为配对错误sign=0;BreakIf(sign=0)BreakElsec=getchar();If(p-next)!=NULL) /最后,确保堆栈中为空sign=0;Return signVoid Judgeout(int a) /判断结果输出If(a=1)Printf(算术表达式括号对有效! n );If(a=0)Printf(算术表达式括号对错误! n );Void main()judge out(judge pair();实验标题:设计算法确定算术表达式是否匹配圆括号。问题分析:该程序判断算术表达式的括号配对是否正确,满足上述功能需要解决的关键问题是判断是否与存储左括号和右括号的过程配对的过程。摘要设计:选择链堆叠,保存需要保存的文字。算术表达式扫描时,左括号重合时进入堆栈。如果右括号匹配,则查看堆栈顶部的文字;如果是左括号,则继续扫描;否则结束扫描。如果遇到其他字符,则继续扫描,而不执行任何操作。详细设计:输入算术表达式后,sign将设置1,然后依次扫描表达式字符。扫描遇到左括号时,将其放入链堆栈。扫描遇到右括号时,查看链堆栈中堆栈顶部的文字,如果堆栈顶部的文字不是左括号,sign设置为0将结束扫描(即表达式括号对无效)。如果堆叠顶部文字为左括号,则堆叠顶部文字将超出堆叠,扫描将继续。如果扫描中有其他字符,则不执行任何操作,继续扫描下一个字符。扫描结束后返回sign的值。如果Sign为0,则表示式括号配对错误。如果Sign为1,表示式括号会正确配对。调试分析和摘要:错误:输入(2 3) (1 2) #无法运行程序。错误堆叠锯函数代码:Char Gettop(Linkstack *S) /获取堆栈顶部数据return S-next-ch;错误分析:当程序扫描算术表达式时,在扫描到右括号时,必须检查文字链堆叠中堆叠顶部的文字。也就是说,必须调用返回节点的字符的堆叠顶部文字函数。扫描两个左括号和右括号,然后扫描到右括号时执行此操作。此时,由于链堆栈为空,设计的函数(在函数代码上)不返回一个字符,因此程序无法成功运行。修改:如果链堆叠为,则返回空格。代码如下:Char Gettop(Linkstack *S) /获取堆栈顶部数据If(S-n
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 铅酸电池外壳解读
- 数控加工技术报告
- 2024学年南京市八年级语文上学期期中考试卷附答案解析
- 医院6S管理实施成果汇报
- 细胞融合技术原理与教学应用
- 三好学生评选个人事迹汇报
- 2026届江苏省南京市燕子矶中学高一化学第一学期期末考试试题含解析
- 线下储值操作讲解
- 全国TRIZ大赛汇报
- 抢救室抢救药物
- 2020-2025年中国智慧仓储行业市场调查研究及投资战略咨询报告
- 什么是个好医护人员的职业素养
- 教育行业服务意识培训
- T-CRHA 085-2024 成人膀胱冲洗并发症护理规范
- Module9 Unit2 Wishing You Happiness Every Day(说课稿)-2023-2024学年外研版(三起)英语六年级下册
- 月嫂资格证考试单选题100道及答案
- 粤沪版物理九年级上册第十二章第1节《认识内能》同步练习
- 水土保持方案投标文件技术部分
- GB/T 3324-2024木家具通用技术条件
- 老挝劳务合同范例
- 空白+彩色世界区域地理填图
评论
0/150
提交评论