实验二 表达式语法分析设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验二 表达式语法分析设计

实验二: 表达式语法分析设计 一、实验目的: 熟悉并设计一个表达式的语法分析器 二、实验内容: 1.设计表达式的语法语法分析器算法 2.编写代码并上机调试运行通过 要求: 输入------------ 表达式 输出------------ 表达式语法是否正确 三、概要设计 采用递归子程序法分析加乘二元表达↓式运算的语法正确性. 程序中表达式文法为: E-T|E+T T-T*F|F F-(E)|i 增加一个产生式:Z-E 流程图: 根据上述流程图的算法,通过子程序的递归调用对二元表达式的语法进行分析. 说明: 本程序只能对加乘二元运算进行语法分析,用i来表示数值. 以#作为结束符. 四﹑源代码设计 #include stdio.h #include malloc.h void E(); void F(); void T(); void T1(); void E1(); struct Lchar{ char char_ch; struct Lchar *next; }Lchar,*p,*h,*temp; char ch; int right; void E(void) //E-T|E+T { T(); E1(); } void T(void) //T-F|T*F { F(); T1(); } void T1(void) // { if(h-char_ch==*){ h=h-next; F(); T1(); } else if(h-char_ch!=#h-char_ch!=)h-char_ch!=+) right=0; } void E1(void){ if(h-char_ch==+){ h=h-next; T(); E1(); } else if(h-char_ch==#||h-char_ch==)) return; else right=0; } void F() //F-(E)|i { if(h-char_ch==i) h=h-next; else if(h-char_ch==() { h=h-next; E(); if(h-char_ch==)) h=h-next; else right=0; } else right=0; } void main() { printf(\n************************* 表达式语法分析器 ***************************\n); printf(\n\n * 简单表达式文法:\n); printf( E-E+T|T\n T-T*F|F\n F-(E)|i\n); printf(\n请输入要判别的表达式(包含字符:i + ( ) *):\n); right=1; h=(struct Lchar *)malloc(sizeof(Lchar)); h-next=NULL; p=h; do{ ch=getchar(); putchar(ch); if(ch==i||ch==+||ch==*||ch==(||ch==)||ch==#){ temp=(struct Lchar *)malloc(sizeof(Lchar)); temp-next=NULL; temp-char_ch=ch; h-next=temp; h=h-next; } else { temp=p-next; printf(\n输入字符错误(或未输入#)!请重新输入!:\n); for(;;) { if (temp!=NULL) printf(%c,temp-char_ch); else break; temp=temp-next; } } }while(ch!=#); p=p-next; h=p; E(); if(h-char_ch==#righ

文档评论(0)

woai118doc + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档