已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
递归下降分析程序实验报告1.实验内容编程实现给定算术表达式的递归下降分析器。算术表达式文法如下:EE+T | T TT*F | F F(E) | i 2.实验分析(1 ) 对所给表达式进行分析,如果是左递归则对算术表达式进行改写消除其左递归。改写的算术表达式如下:ETE E+TE| TFT T*FT | F(E) | i( 2) 写出上面表达式的FIRST集和FOLLOW集,然后对有多个规则的FIRST集求并集,看是否等于空集;对规则右部出现空串的FIRST集与FOLLOW集求并集,看是否等于空集。 对E:FIRST(+TE) FOLLOW(E)=+, #, )=对T:FIRST(*FT) FOLLOW(T)=* , +,#, )=对F: FIRST(i) FIRST( (E) )=i ( =故由上面可知此改写后的文法是LL(1)文法。(3)对上述LL(1)文法编程。编程规则如下:当遇到终结符a时,则编写语句If(当前读来的输入符号=a)读下一个输入符号当前遇到非终结符A时,则编写语句调用A()。当前遇到A规则时,则编写语句If(当前读来的输入符号不属于FOLLOW(A) error()当某个非终结符的规则有多个候选式时,按LL(1)文法的条件能惟一地选择一个侯选式进行推导。3.源程序代码#includeusing namespace std; #include #define n 100 char chn; int k=0; void scaner(); void E(); void E1(); void T(); void T1(); void F();void Error();void scaner()k+;void E()T();E1();void E1()if (chk=+) scaner();T();E1(); else if(chk!=)&chk!=#) Error();void T()F();T1();void T1() if(chk=*) scaner();F();T1();else if(chk=+&chk!=)&chk=#)Error();void F()if(chk=() scaner(); E(); if(chk=) scaner();else Error();else if(chk=i)scaner();else Error();void Error() cout语法错误 !endl;cout分析失败endl; exit(0); void main() k=0; coutch; E(); if (chk=#)cout分析成功!endl; elsecout分析失败endl;4.测试用例1图1:输入i时成功图1 输入i匹配成功2图2:输入i+i*i时成功图2 输入i+i*i匹配成功3图3:输入(i)时成功图 3 输入(i)匹配成功4图4:输入(i+(i*i)时成功图 4 输入(i+(i*I)匹配成功5图5:输入i+i时成功图 5 输入i+i匹配成功6图6:输入i*i时成功图6 输入i*i匹配成功7图7:输入(i*i)时成功图 7 输入(i*i)时匹配成功8图8:输入(i+i)时成功图8 输入(i+i)时匹配成功9图9:输入i+i+i+i+i+i时成功图9 输入i+i+i+i+i+i时匹配成功10图10:输入i*i*i*i*i*i*i*i时成功图 10 输入i*i*i*i*i*i*i时匹配成功11图11:输入+i时失败图11 输入+i时匹配失败12图12:输入ii时失败图12 输入ii时匹配失败13图13:输入()时失败图 13 输入()匹配失败5.实验总结本次实验主要是根据一个算术表达式文法构造一个识别该文法句子的递归下降分析程序。它的主要功能是当输入一个算术表达式时,判断该表达式是否能从文法开始符号出发推导出来。若能,则说明语法分析成功,否则失败。实验主要使用了C+和Visual Studio 2005,定义了几个函数然后调用函数,程序比较简单。本次实验的最终运行结果与预期结果是完全一致的。同时在程序由于不能把全部的错误与正确的用例都包含进去,所以不能验证程序的正确性。在实验开始写程序前要做好充分的准备。例如判断文法是否含有文法左递归、是不是LL(1)文法,并想好测试用例,用例的选择非常重要,因为若某一方面没有考虑到就会导致程序错误。我在写程序时并未考虑用例“i)#”,因此运行出错,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026江苏无锡市江阴市水利投资发展集团有限公司子公司招聘1人考试备考题库及答案解析
- 2026广东广州市教育局直属事业单位广州市艺术中学第一次招聘教师25人笔试模拟试题及答案解析
- 2026年巴音郭楞蒙古市气象系统事业单位人员招聘考试备考试题及答案详解
- 2026年楚雄市水利系统事业单位人员招聘考试备考试题及答案详解
- 2026年东莞市不动产登记中心人员招聘考试备考试题及答案详解
- 2026年潮州市城管协管人员招聘考试备考试题及答案详解
- 2026年巴中市住房和城乡建设系统事业单位人员招聘考试备考试题及答案详解
- 外研版(三起)(孙有中)四年级下册英语期中测试题(解析版)
- 2026年阿勒泰市建设系统事业单位人员招聘考试备考试题及答案详解
- 就业指导谈话技巧
- 2026年设备安装质量员考试题库(附答案)
- 2026中原豫资投资控股集团秋招试题及答案
- 2026中国旅游集团总部及所属企业岗位招聘9人参考题库附答案
- 2026年上海市黄埔区初三上学期一模数学试卷和参考答案
- 2026年美的数字化转型岗-AI-面试专项训练题含答案
- 幼儿园公众号培训课件
- 油田钻井监督岗位培训考试题全集
- 休克病人护理健康教育
- 狐狸的清白教学课件
- 村级治理课件
- 2025年拼多多客服知识考核试题及答案
评论
0/150
提交评论