《编译原理及实践教程》第3章词法分析.ppt

  1. 1、本文档共103页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《编译原理及实践教程》第3章词法分析

方法如下: 正规式R?有穷自动机NFA M ? s,t是正规式,相应NFA为N(s),N(t),则正规式R=s|t,构造NFA(R) 为: ? 对应正规式a,构造NFA为: ? 对应正规式?,构造NFA为: ? 正规式?,构造NFA为: x y ? x y ? ? x y a ? ? s,t是正规式,相应NFA为N(s),N(t),则正规式R=st,构造NFA(R) 为: ? s是正规式,相应NFA为N(s) ,则正规式R=s*,构造NFA(R) 为: 书上例3.15 R = 1的有穷自动机: R = 1*的有穷自动机: R = 01*的有穷自动机: q0 q1 1 q0 q1 1 q2 q3 ? ? ? ? q0 q1 1 ? q2 q3 ? ? ? q4 q5 0 0 R = 01* | 1的有穷自动机: q0 q1 1 ? q2 q3 ? ? ? q4 q5 0 q6 q7 1 Y X ? ? ? ? 0 练习 a a ? ? ? ? b ? ? q0 ? ? b b 正规式L(R) =(a|b)*abb,构造NFA使L(N)=L(R) a b b 本章小结 本章要求 1.词法分析器的作用和接口,用高级语言编写词法分析器。 2.掌握正规式、正规文法和有穷自动机的相关概念,它们之间转换的技巧、方法或算法。 ? NFA ? DFA ? DFA ? 最简DFA ? 非形式描述的语言 ? 正规式 ? 正规式 ? NFA ? 正规文法 ? NFA 课堂练习(1~3章) 1. 有文法G[S]: 问:符号串aidtcBcAb、ab、abidt是否是该文法的句型?为什么? 2. 编译原理各个阶段各应遵循哪些原则? 3. 写出不能被5整除的偶整数的正规文法和正规式 4. 有一台自动售货机,接受1元和5角的硬币,出售每瓶1元5角的饮料,顾客每次向机器中投放?1元5角的硬币,就可得到一瓶饮料( 注:每次只给一瓶饮料,且不找钱),构造该售货机的有穷自动机。 5. 设计一个状态数最少的DFA, 其输入字母表是{0,1},它能接受以00或01结尾的所有序列,并给出相应的正规文法。 S ? aAb A ? BcA | B B ? idt | ? 3.4词法分析程序的自动构造 对有穷自动机和正规表达式进行了上述讨论之后,介绍词法分析程序的自动构造方法,这个方法基于有穷自动机和正规式的等价性,即: 1.对于∑上的一个NFA M,可以构造一个∑上的正规式R,使得L(R)=L(M)。 2.对于∑上的一个正规式R,可以构造一个∑上的NFA M,使的L(M)=L(R)。 * 为什么要做这样的变换:因为NFA中每条弧用?* 上的一个字来表示,而DFA每条弧用? 上的一个符号来表示;DFA有1个开始状态,而NFA可以有多个初始状态。 * 转换后是一个不确定的有穷自动机 * 从书上的证明过程来看,从正规文法到有穷自动机,只有一个终结状态F,因此不能得到B是终结状态 * 识别所有偶数个1和偶数个0的语言 定义1:状态集合I的ε-闭包—— ε-Closure(I) 若状态q ∈ I,则q ∈ ε-Closure(I); 若状态q ∈ I,则从q出发经任意条ε弧而能到达的状态q′ 都属于ε-Closure(I) 。 NFA转化为等价的DFA(NFA的确定化) ?-closure(I)={5,4,6,2,7} 1 2 5 3 4 6 8 7 a a ? ? ? ? ? a 例: I={1}, ?-closure(I)={1,2}; I={5}, ?-closure(I)={5,6,2}; I={5,4}, ?-closure(I)=? ε-Closure(I)总结 (1) 状态集I的ε-Closure(I)仍是一状态集; (2) 此状态集(ε-closure(I))即为在I状态下,不输入任何字符所能到达的状态的全体并包含I的状态,即I状态下ε的闭包。 I={1,2}, J= {5,3,4} ; Ia= ?-closure({5,3,4})={2,3,4,5,6,7,8} 1 2 5 3 4 6 8 7 a a ? ? ? ? ? a 定义2:状态集合I的a弧转换——Ia Ia = ε-closure(J) 其中J是所有那些可从I中的某一状态结点出发经过一条a弧而到达的状态的全体。 例:若I={1}, 则输入a的后继为J= {5, 4} ; Ia= ?-closure(J)=?-closure {5, 4})={2,4,5,6,7} 若I={1,2}, Ia=? 总结—求Ia步骤: (1) 求J,即求在I状态(集合)输入a的后继状态(集合); (2) 求ε-

文档评论(0)

jiayou10 + 关注
实名认证
内容提供者

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

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档