5.2LL文法的判别.pptVIP

  1. 1、本文档共22页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
? LL(1)文法的判别 文法化简 - 不含有有害规则和多余规则 消除左递归和提左公因子 求出能 ε的非终结符☆ 计算FIRST集☆ 计算FOLLOW集☆ 计算SELECT集☆ (3). 求出能推出ε的非终结符 算法描述 建立一个一维数组X[ ],用以记录非终结符能否推出ε。 ① 将数组X[ ]中对应每一非终结符的标记置初值为“未定”。 …… ② 扫描文法中的产生式。 (a) 若某一非终结符的某一产生式右部为ε, 则将数组中对应该非终结符的标志置为“是”, 并从文法中删除该非终结符的所有产生式。 (b) 若某一产生式右部含有终结符,则删除该产生式。(右部含有终结符,一定无法推出ε) 若这使得以某一非终结符为左部的所有产生式都被删除,则将数组中对应该非终结符的标记值改为否。 …… ③ 扫描产生式右部的每一符号。 (此时产生式右部全部为非终结符) (a) 若扫描到的非终结符在数组中对应的标志是是,则删去该非终结符, 若这使产生式右部为空,则对产生式左部的非终结符在数组中对应的标志改“是”,并删除该非终结符为左部的所有产生式。 (b) 若扫描到的非终结符在数组中对应的标志是否,则删去该产生式, 若这使产生式左部非终结符的有关产生式都被删去,则把在数组中该非终结符对应的标志改成“否”。 …… ④ 重复③,直到扫描完一遍文法的产生式,数组中非终结符对应的特征再没有改变为止。 (4). 计算FIRST集 对每一文法符号X∈V , 计算FIRST(X) (a) 若X∈VT,则FIRST(X)={X} (b) 若X∈VN,且有产生式 X→ a… , a∈VT , 则 a∈FIRST(X) 即把a加入到FIRSR(X)中 (c) 若X∈VN,且有产生式 X→ε, 则ε∈FIRST(X) …… (d) 若X∈VN, 且有产生式 X→Y1 Y2 …Yi-1 Yi … Yn, 当Y1 Y2 … Yi-1都能推出ε时, 则 FIRST(Y1)-{ε} FIRST(Y2)-{ε} …… FIRST(Yi-1)-{ε} FIRST(Yi) 都包含在FIRST(X)中 …… (e) 当(d)中X→Y1 Y2 … Yn 所有Yj 都可以推出ε, (j=1,2,…n) , 则 FIRST(Y1) FIRST(Y2) …… FIRST(Yn) 都包含在FIRST(X)中 反复使用上述(b)~(e)步直到每个符号的FIRST集合不再增大为止。 求一个符号串α的FIRST集合 若符号串α∈V*,α= X1 X2 … Xi-1 Xi … Xn, 若X1不能推导出ε, 则 FIRST(α)= FIRST(X1) 若对任何j (1≤j≤i-1, 2≤i≤n) ε∈FIRST(Xj) 若对任何j (1≤j≤n) ε∈FIRST(Xj), 例: 求FIRST集 G: E → TE E→ +TE|ε T → FT T→ *FT|ε F → (E) | i (5). 计算FOLLOW集 (a) 设S为文法中开始符号, 把 # 加入FOLLOW(S)中 (b) 若 A→αBβ 是一个产生式, 则把 FIRST(β)\{ε} 加入 FOLLOW(B) 中 (c) 若 A→αB 是一个产生式, 或 A→αBβ 是一个产生式,且β可推出ε, 即ε∈FIRST(β) , 则把 FOLLOW(A) 也加入 FOLLOW(B) 中 (d) 反复使用(b)直到每个非终结符的FOLLOW集不再增大为止。 例: 求FOLLOW集 G: E →TE E→+TE|ε T →FT T→*FT|ε F →(E) | i 例: LL(1)文法判别 (6). 计算SELECT集 给定上下文无关文法的产生式A→α, A∈VN, α∈V*, 若α ε, SELECT(A→α) = FIRST(α) 若α ε, SELECT(A→α) = (FIRST(α)-{ε})∪ FOLLOW(A) 例: 判断文法是否是LL1文法 G: S→AB S→bC A→b A→ε B→ε B→aD C→b C→AD D→aS D→c 求出能推出ε的非终结符 G: S→AB S→bC A→b A→ε B→ε B→aD C→b C→AD D→aS D→c 计算FIRST集 G: S→AB S→bC A→b A→ε B→ε B→aD C→b C→AD D→aS D→c 计算

文档评论(0)

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

分享好文档!

1亿VIP精品文档

相关文档