[第4章语法分析.3..pptVIP

  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文档。上传文档
查看更多
[第4章语法分析.3.

* 设句型为β: 1、先画出对应句型β的语法树; 2、找出该语法树中所有相邻终结符之间的优先关系。 语法树确定相邻终结符之间优先关系的原则如下: ① 同层:优先关系为“=”; ② 不同层:层次在下的优先级高,层次在上的优先级低; ③ 在句型β两侧加上语句括号“#”,即#β#, 则有:# β 和 β #。 3、按最左素短语必须具备的三个条件来确定最左素短语。 语法树法查找最左素短语 4.6 算符优先分析法 Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. * G[E]: (1) E→E+T (2) E→T (3) T→T*F (4) T→F (5) F→(E) (6) F→i 短语有:T+T*F+i,T+T*F, T,T*F,i 最左素短语为:T*F 【例】#i1*(i2+i3)# ∵ #i1*(i2+i3)# ∴ i1,i2,i3是素短语;i1是最左素短语。 #+*+i# 【例】句型 #T+T*F+i# 4.6 算符优先分析法 E T i E T + E T + T F * Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. * 根据最左素短语的定理,最左素短语中的终结符号具有相同的优先关系。并且,由于最左素短语中的符号是当时最先要归约的串,其优先关系先于最左素短语之外的符号,所以我们使用一个用于存放文法符号的先进后出栈,并利用优先关系表,可以确定最左素短语是否已形成来决定分析器的动作。 算符优先分析程序的设计 4.6 算符优先分析法 Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. * 4.6 算符优先分析法 算符优先分析算法描述 k=1,s[k]=‘#’ ;//s为符号栈,‘#’压入栈,s[k]为栈顶项 do{ a=getsym( );//读入下一个符号给a if(s[k]∈VT ) j=k; else j=k-1; while(s[j] a){ do{//在栈中寻找满足的s[j]s[j+1]=…=s[k]a的s[j+1], 即最左素短语的头 Q= s[j] ; if(s[j-1]∈VT) j=j-1; else j=j-2; } while(s[j]=Q) s[j+1]…s[k]?N; //归约最左素短语 k=j+1; s[k]=N;}//end of while if(s[j]a||s[j]=a){k=k+1;s[k]=a;} //移进 else error}while(a!=‘#’ || 符号栈中不是#S) Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. * 寻找满足的s[j]s[j+1]=…= s[k]a的s[j+1],即最左素短语的头。 向栈中移进符号, 以形成最左素短语。 Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. * 4.6 算符优先分析法 算符优先分析算法举例 【例】设文法G[E]: E→E+T | E→T T→T*F | T→F F→(E) | F→i 试用算符优先分析法分析句子i+i*i 1.每次规约当前句型的最左素短语 2.不一定是规范规约 Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose

文档评论(0)

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

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

1亿VIP精品文档

相关文档