[教育学]复习.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文档。上传文档
查看更多
[教育学]复习

编译原理 第一章 引论 一. 什么是编译程序 第二章 高级语言及其语法描述 上下文无关文法的定义: 一个上下文无关文法G是一个四元式 G=(VT,VN,S,P), 题型 已知文法G(Z): Z → 0U │ 1V U → 1Z │ 1 V → 0Z │ 0 (1)写出此文法描述的只含有4个符号的全部句子 (2)该文法描述的语言是什么? 二、推导、语法树、二义性 最左推导:任何一步? ? ?都是对?中的最左非终结符进行替换。 最右推导:任何一步? ? ?都是对?中的最右非终结符进行替换。 用一张图表示一个句型的推导,称为语法树。 如果一个文法存在某个句子对应两颗不同的语法树,则说这个文法是二义的。 0型(短语文法,图灵机): 产生式形如: ? ? ? 其中:?? (VT ? VN)*且至少含有一个非终结符;?? (VT ? VN)* 1型(上下文有关文法,线性界限自动机): 产生式形如: ? ? ? 其中:|?| ? |?|,仅 S?? 例外。 题型 P36 7、8、9、11 第三章 词法分析 一、正规式、正规集、DFA、NFA 正规集:以01结尾的二进制数串 正规式: (0/1)*01 (a|b)*(aa|bb)(a|b)* 习题 P64 12、14 第四章 语法分析 -------自上而下分析 LL(1)文法 L:从左到右扫描输入串 L:最左推导 1:分析时每一步只需向前查看一个符号 相关题型 消除左递归 FIRST集和FOLLOW集的构造 一、消除左递归 直接左递归 P→P?1 | P?2 | … | P?m | ?1 | ?2|…|?n 变换成 P→?1P? | ?2P? | … | ?nP? P?→?1P? | ?2P? |… | ?mP? | ? 间接左递归 例 考虑文法G(S) S→Qc|c Q→Rb|b R→Sa|a 令它的非终结符的排序为R、Q、S。 Q的规则变为 Q→Sab | ab | b 现在的Q不含直接左递归,把它代入到S的有关候选后,S变成 S→Sabc | abc | bc | c 例 考虑文法G(S) S→Qc|c Q→Rb|b R→Sa|a S变成 S→Sabc | abc | bc | c 消除S的直接左递归后: S→abcS? | bcS? | cS? S?→abcS? | ? Q→Sab |ab | b R→Sa|a 例 考虑文法G(S) S→Qc|c Q→Rb|b R→Sa|a 消除S的直接左递归后: S→abcS? | bcS? | cS? S?→abcS? | ? Q→Sab |ab | b R→Sa|a 关于Q和R的规则已是多余的,化简为: S→abcS? | bcS? | cS? S?→abcS? | ? (4.4) 二、构造FIRST(?) 对每一文法符号X?VT∪VN构造FIRST(X) 连续使用下面的规则,直至每个集合FIRST不再增大为止: 1. 若X?VT,则FIRST(X)={X}。 2. 若X?VN,且有产生式X→a…,则把a加入到FIRST(X)中;若X→?也是一条产生式,则把?也加到FIRST(X)中。 3. 若X→Y…是一个产生式且Y?VN,则把FIRST(Y)中的所有非?-元素都加到FIRST(X)中; 若X→Y1Y2…Yk是一个产生式,Y1,…,Yi-1都是非终结符,而且,对于任何j,1?j?i-1,FIRST(Yj)都含有?(即Y1…Yi-1?), 则把FIRST(Yi)中的所有非?-元素都加到FIRST(X)中;特别是,若所有的FIRST(Yj)均含有?,j=1,2,…,k,则把?加到FIRST(X)中。 对文法G的任何符号串?=X1X2…Xn构造集合FIRST(?)。 1. 置FIRST(?)=FIRST(X1)\{?}; 2. 若对任何1?j?i-1,??FIRST(Xj),则把FIRST(Xi)\{?}加至FIRST(?)中;特别是,若所有的FIRST(Xj)均含有?,1?j?n,则把?也加至FIRST(?)中。显然,若?=?则FIRST(?)={?}。 三、构造FOLLOW(A) 对于文法G的每个非终结符A构造FOLLOW(A)的办法是,连续使用下面的规则,直至每个FOLLOW不再增大为止: 1. 对于文法的开始符号S,置#于FOLLOW(S)中; 2. 若A→?B?是一个产生式,则把FIRST(?)-{?}加至FOLLOW(B)中; 例4.6 对于文法G(E) E→TE? E?→+TE? | ? T→FT?

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档