2023年编译原理学习笔记.pdf
《2023年编译原理学习笔记.pdf》由会员分享,可在线阅读,更多相关《2023年编译原理学习笔记.pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、学习必备 欢迎下载 本份资料是 03 软件学习委员按照老师上课复习的时候给我们讲的一些考试重点考点,和我看书上网查资料等总结出来的一份复习笔记,一些是自己总结出来的方法,有一些考点这份笔记没有覆盖到,请大家补充.严重声明:仅是个人的理解,如果有错请高手们指出,以免误人,谢谢如果大家有什么不明,可以共同探讨 几种文法的区分:文法分为四类:(1)短语文法(0 型文法)(2)上下文相关文法(1 型文法)(3)上下文无关文法(2 型文法)(4)正规(则)文法(3 型文法)上面四种文法有包含的关系,1 型文法是 0 型文法的一个子集,2 型文法是 1 型文法的一个子集,,3 型文法是 2 型文法的一个子
2、集。一些判断和排除的技巧:1.正规文法右边只有一个非终止符,eg:S AB 可排除此文法是正规文法.2.区分上下文相关文法和上下文无关文法的情况:看左端有几个非终止符,如果不只一个,则该文法不是上下文无关文法.AB a 可排除上下文相关文法,A a 则可能是上下文无关文法.3.对于S 若其他推导式中S 不出现在其他产生式的右边,不影响正规文法要求,若出现在右边,则是短语文法.eg:B cB 则一定是短语文法.4.A aB 或者 A a 则属于右线性文法,A Ba 或 A a 属于左线性文法.若一个文法有型如A aB 又有 A Ba 的推导式,则排除该文法最多是正规文法.短语文法 上下文相关文法
3、 上下文无关文法 正规 左线性 右线性 学习必备 欢迎下载 给出文法 用最左或最右推导句子建立推导树 例:已知文法 G:E-E+T|E-T|T T-T*F|T/F|F F-(E)|i 试给出下述表达式的推导及语法树 (1)i;(2)i*i+i (3)i+i*i (4)i+(i+i)答案 (1)E=T=F=i (2)E=E+T=T+T=T*F+T=F*F+T=i*F+T=i*i+T=i*i+F=i*i+i (3)E=E+T=T+T=F+T=i+T=i+T*F=i+F*F=i+i*F=i+i*i (4)E=E+T=T+T=F+T=i+T=i+F=i+(E)=i+(E+T)=i+(T+T)=i+(F
4、+T)=i+(i+T)=i+(i+F)=i+(i+i)给出语言 写出文法(题型可参照书本 p39 2-2)例:给出语言 anbncm|n=1,m=0 的上下文无关文法。解:基本思路是这样的:要求符合 anbncm,因为 a 与 b 要求个数相等,所以把它们应看作一个整体单元进行,而 cm做为另一个单位,初步产生式就应写为 S-AB,其中 A 推出anbn,B 推出 cm。因为 m 可为 0,故上式进一步改写为 S-AB|A。接下来考虑A,凡是要求两个终结符个数相等的问题,都写为 A-aAb|ab形式,对于 B 就很容易写成 B-Bc|c了。构造上下文无关文法如下:S-AB|A A-aAb|ab
5、 仅是个人的理解如果有错请高手们指出以免误人谢谢如果大家有什么不法是型文法的一个子集型文法是型文法的一个子集型文法是型文法的一关文法和上下文无关文法的情况看左端有几个非止符如果不只一个则该学习必备 欢迎下载 B-Bc|c 证明文法的二义性(题型可参照书本 p40 2-10,方法用老师给的方法)基本思路:找出一个句子,证明它可从两种推导方式得到相同的推导结果即可.例:证明下面文法具有二义性.S-aB|bA B-bS|aBB|b A-aS|bAA|a 找出一句子 aabbab 有两种不同的推导。S=aB=aaBB=aabB=aabbS=aabbaB=aabbab S=aB=aaBB=aabSB=a
6、abbAB=aabbaB=aabbab 即它可以产生两棵不同的语法树,故它是二义的。关于 NFA 确定化和 DFA 的最小化详见老师给出的习题答案.消除左递规 直接左递规:左递归产生式 AA,可以用非左递归的 A A A A|来代替,它们没有改变从 A 推导出的串集。eg:T T*F|F 消除左递规得:T FT ;T *F T|例题可参照书本 p109 总结:不管有多少 A 产生式,可以用下面的技术消除直接左递归。首先把 A 产生式组在一起:A A1|A2|Am|1|2|n 其中i都不以 A开始,i都非空,然后用 A 1A|2 A|n A A 1A|2 A|m A|代替 A产生式。这些产生式和
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2023 编译 原理 学习 笔记
限制150内