- 1、本文档共103页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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) 求ε-
您可能关注的文档
- 微波技术基础_绪论_1概要.ppt
- 微波技术基础第2章传输线理论概要.ppt
- 微波水处理技术概要.pptx
- 微波技术第一章----绪论last概要.ppt
- 微波滤波器的设计制作与调试概要.ppt
- 微波滤波器和无源电路讲座(14_a)概要.pptx
- 微波技术习题答案概要.doc
- 微流控芯片技术在环境领域的应用和展望概要.ppt
- 微模块介绍概要.ppt
- 微生物基因工程菌概要.ppt
- 半导体材料性能提升技术突破与应用案例分析报告.docx
- 半导体设备国产化政策支持下的关键技术突破与应用前景报告.docx
- 剧本杀市场2025年区域扩张策略研究报告.docx
- 剧本杀行业2025人才培训体系构建中的市场需求与供给分析.docx
- 剧本杀行业2025年人才培训行业人才培养模式创新与探索.docx
- 剧本杀行业2025年内容创作人才需求报告.docx
- 剧本杀行业2025年区域市场区域剧本市场消费者满意度与市场竞争力研究报告.docx
- 剧本杀市场2025年区域竞争态势下的区域合作策略分析报告.docx
- 剧本杀行业2025人才培训与行业人才培养模式创新.docx
- 剧本杀行业剧本创作人才心理素质培养报告.docx
最近下载
- T_HNTI 030—2020_茶树种质资源考察收集技术规范.pdf VIP
- 报关原理与实务(第二版)(第5章)1进出口货物报关单填制.ppt VIP
- 2025年滨州市中考英语试题卷(含答案逐题解析).docx
- 基于能力培养的人工智能课程体系设计.docx
- Q/GDW1827-2013三相智能电能表技术规范.pdf VIP
- 国家中医药管理局发布的406种中医优势病种诊疗方案和临床路径目录.pptx VIP
- 华能国际电力股份有限公司本质安全体系管理手册.doc VIP
- 教育行业AI大模型设计方案【231页WORD】.docx VIP
- 2024医保物价培训.pptx VIP
- 屋顶光伏发电建设项目实施方案.docx
文档评论(0)