设计算法判断一个算术表达式的圆括号是否配对_第1页
设计算法判断一个算术表达式的圆括号是否配对_第2页
设计算法判断一个算术表达式的圆括号是否配对_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

#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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论