LL(1)文法分析程序实验报告.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文档。上传文档
查看更多
LL(1)文法分析程序实验报告 学 院: 计算机科学与信息学院 班 级: ×××× 学 号: 1109××××× 姓 名: ××× 指导老师: 孙老师 专 业: 计算机科学与技术 计算机科学与技术系 1、概述 当我们需选用自顶向下分析技术来分析文法时,首先必须判别所给文法是否是LL(1)文法。因而我们对任给文法需计算FIRST、FOLLOW、SELECT集合,进而判别文法是否为LL(1)文法。 2、LL(1)的判定步骤 2.1、求出能推出ε的非终结符 首先建立一个以文法的非终结符个数为上界的一维数组,其数组元素为非终结符,对应每一非终结符有一标志位,用以记录能否推出ε。其值有三种情况:未定、是、否。 ① 将数组X[ ]中对应每一非终结符的标记置初值为未定。 ② 扫描文法中的产生式。   (a) 删除所有右部含有终结符的产生式,若这使得以某一非终结符为左部的所有产生式都被删除,则将数组中对应该非终结符的标记值改为否,说明该非终结符不能推出ε。   (b) 若某一非终结符的某一产生式右部为ε,则将数组中对应该非终结符的标志置为是,并从文法中删除该非终结符的所有产生式。例中对应非终结符A、B的标志改为是。 ③ 扫描产生式右部的每一符号。   (a) 若所扫描到的非终结符号在数组中对应的标志是是,则删去该非终结符,若这使产生式右部为空,则对产生式左部的非终结符在数组中对应的标志改是,并删除该非终结符为左部的所有产生式。   (b) 若所扫描到的非终结符号在数组中对应的标志是否,则删去该产生式,若这使产生式左部非终结符的有关产生式都被删去,则把在数组中该非终结符对应的标志改成否 ④ 重复③,直到扫描完一遍文法的产生式,数组中非终结符对应的特征再没有改变为止。 2.2、计算FIRST集   (a) 若X∈VN,且有产生式X→a…,a∈VT, 则 a∈FIRST(X)。   (b) 若X∈VN,X→ε,则ε∈FIRST(X)。   (c) 若X∈VN;Y1,Y2,…,Yi∈VN,且有产生式X→Y1 Y2 … Yn;当Y1 Y2 … Yi-1都ε时,(其中1≤i≤n),则FIRST(Y1)、FIRST(Y2)、…、FIRST(Yi-1)的所有非{ε}元素和FIRST(Yi)都包含在FIRST(X)中。 (d) 当(d)中所有Yi ε,(i=1,2,…n),则 FIRST(X)=FIRST(Y1)∪FIRST(Y2)∪…∪FIRST(Yn)∪{ε},反复使用上述(a)~(d)步直到每个符号的FIRST集合不再增大为止。 2.3、 计算FOLLOW集   对文法中每一 A∈VN 计算 FOLLOW(A)   (a) 设S为文法中开始符号,把{#}加入FOLLOW(S)中(这里#为句子括号)。   (b) 若A→αBβ是一个产生式,则把FIRST(β)的非空元素加入FOLLOW(B)中。   如果β ε则把FOLLOW(A)也加入FOLLOW(B)中。   (c) 反复使用(b)直到每个非终结符的FOLLOW集不再增大为止。 2.4、计算SELECT集 对文法中每一 A-a,A∈VN ,a属于V*,若a不能推出空,则SELECT(A-a)=FIRST(a)。否则 SELECT(A-a)={FIRST(a)-{ε}UFOLLOW(A)。 2.5、判定 对于每个非终结符的两个不同产生式,A-a,A-b,满足SELECT(A-a)ΠSELECT(A-b)=ф。 其中a,b不能同时推出ε。 3、预测分析 3.1、构建文法的预测分析表 分析表又可用一个矩阵M(或称二维数组)表示。矩阵的元素M[A,a]中的下标A表示非终结符,a为终结符或句子括号#,矩阵元素M[A,a]中的内容为存放着一条关于A的产生式,表明当用非终结符A向下推导时,面临输入符a时,所应采取的候选产生式,当元素内容无产生式时,则表明用A为左部向下推导时遇到了不该出现的符号,因此元素内容为转向出错处理的信息。 3.2、预测分析程序框图 4、文法分析实现 5、实验心得 本次实验利用自上而下的分析方法对任给的文法进行判断,基本完成了实验要求,但仅仅局限于LL(1)文法才能用,具有一定的局限性。一些文法消除了左递归或是提取了左公共因子后也有可能为LL(1)文法,但本实验并未给出解决方法。 参 考

文档评论(0)

134****9237 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档