语法分析实验报告.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文档。上传文档
查看更多
语法分析实验报告 一:实验内容: 编写语法分析程序,实现对算术表达式的语法分析,要求所分析的算术表达式由如下的文法产生。 E-E+T|E-T|T T-T*F|T/F|F F-id|(E)|num 二:实验要求: 在对表达式进行分析的同时,输出所采用的产生式。 1.编写LL(1)语法分析程序,要求: 编程实现算法4.2,为给定的文法自动构造预测分析表 编程实现算法4.1,构造LL(1)预测分析程序, 2.编写语法分析程序,实现自底向上的分析,要求: 构造识别所有活前缀的DFA 构造LR分析表 编程实现算法4.3,构造LR分析程序 三:实验分析: 方法二(编写LL(1)语法分析程序) 1.步骤: (1)根据题目所给出的文法构造相应的无左递归文法,并求出该文法各非终结符的FIRST、FOLLOW集合; (2)构造文法的LL(1)分析表; (3)由此构造LL分析程序。 2.实现方法: 1.输入缓冲区为一个字符型数组,读入输入的算术表达式并保存在此,以’$’结束; 2.为构造文法的LL(1)分析表,构建一个相对应的字符串数组; 3.在实际程序中P代表E,Q代表T,e代表ε,i代表id,n代表num; 4.处理输入表达式中代表id和num的子串,分别将它们转化为i和n进行分析; 5. LL(1)预测分析程序的总控程序在任何时候都是按STACK栈顶符号X和当前的输入符号a做哪种过程的。对于任何(X,a),总控程序每次都执行下述三种可能的动作之一: (1)若X = a =‘$’,则宣布分析成功,停止分析过程。 (2)若X = a!=‘$’,则把X从STACK栈顶弹出,让a指向下一个输入符号。 ①如果是终结符合,则栈不加入新符号 ②如果是非终结符合,则把表达式右边入栈 (3)若M[A,a]中存放着“出错标志”,则调用出错诊断程序ERROR。 3.计算过程: 文法对应的无左递归文法为: E-TE’ E’-+TE’|-TE’|ε T-FT’ T’-*FT’|/FT’|ε F-id|(E)|num 求的各个非终结符的FIRST、FOLLOW集合为: FIRST(E) = { id, num, ( } FOLLOW (E) = { $ , )} FIRST(E’) = { +, -,ε} FOLLOW (E’) = { $ , )} FIRST(T) = { id, num, ( } FOLLOW (T) = { $ , + , - , )} FIRST(T’) = { *,/,ε( } FOLLOW (E’) = { $ , + , - , )} FIRST(F) ={ id, num, ( } FOLLOW (F) = { $ , + , - , * , / , ) } 方法三(编写语法分析程序,实现自底向上的分析) 1.步骤: (1)根据题目所给出的文法构造相应的拓广文法,并求出该文法各非终结符的FIRST、FOLLOW集合; (2)构造拓广文法的项目集规范族,并构造出识别所有前缀的DFA; (3)构造文法的LR分析表; (4)由此构造LR分析程序。 2.实现方法: 1.输入缓冲区为一个字符型数组,读入输入的算术表达式并保存在此,以’$’结束; 2.定义两个二维整形数组,goto和action,其值大于零代表移进操作,小于零代表规约操作,引进的状态或规约用到的产生式又绝对值表示。等于零代表出现错误。等于特殊值-10代表acc.状态。 3.在实际程序中P代表E,Q代表T,e代表ε,i代表id,n代表num; 4.处理输入表达式中代表id和num的子串,分别将它们转化为i和n进行分析; 5.根据分析表,相应进行语法分析,移近或规约,按算法4.3的步骤完成过程。 3.计算过程: 文法对应的拓广文法为: (0)E’-E (1) E - E+T (2)E - E-T (3) E - T (4)T - T*F (5)T - T/F (6)T - F (7)F - (E) (8)F - id (9)F - num 求的各个非终结符的FIRST、FOLLOW集合为: FIRST(E’) = { id, num, ( } FOLLOW (E’) = { $ } FIRST(E) = { id, num, ( } FOLLOW (E) = { $ , + , - , ) } FIRST(T) = { id, num, ( } FOLLOW (T) = { $ , + , - , * , / , ) } FIRST(F) ={ id, num, ( } FOLLOW (F) = { $ , + , - , * , / , ) } 4.SLR(1)分析表为: 状态 + - * / ( ) Id Num $

文档评论(0)

138****4229 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档