NFA转化为DFA的转换算法及实现.docVIP

  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文档。上传文档
查看更多
PAGE PAGE 23 编译原理课程实践报告 设计名称:NFA转化为DFA的转换算法及实现 二级学院: 数学与计算机科学学院 专 业: 计算机科学与技术 班 级: 计科本091班 姓 名: 学 号: 指导老师: 日 期: 2012年6月28日 摘要 有穷自动机分为确定的有穷自动机(DFA)和不确定的有穷自动机(NFA)两类。两者各有特点、作用于不同的地方,因此需要进行转化。NFA转化为DFA的理论在词法构造乃至整个编译器构造过程中起着至关重要的作用,同时它们被广泛应用于计算机科学的各个领域,它们与计算机其它学科之间也有着很密切的关系。 本文主要介绍基于编译器构造技术中的由NFA转化为DFA的算法设计和实现技术:主要包括NFA转化为与其等价的DFA所使用的子集构造算法以及把DFA化简的算法,实现词法分析,最后使用Visual C++语言加以实现。 NFA转化为与其等价的DFA需分两步进行:1、构造NFA的状态的子集的算法;2、计算ε-closure。完成这些子模块的设计后,再通过某一中间模块的总控程序对其调用,最后再由主程序总调用,也就实现了NFA转化为其等价的DFA,接下来就是以分割法的思想为指导实现DFA的化简,最后并以实例加以说明。 关键词:有穷自动机;NFA ;DFA; 转化 ; 化简 目录 TOC \o 1-3 \h \z \u HYPERLINK \l _Toc328680889 1 前言 PAGEREF _Toc328680889 \h 3 HYPERLINK \l _Toc328680890 1.1 选题的依据和必要性 PAGEREF _Toc328680890 \h 3 HYPERLINK \l _Toc328680891 1.2 课题意义 PAGEREF _Toc328680891 \h 3 HYPERLINK \l _Toc328680892 2 NFA转化为DFA的算法及实现 PAGEREF _Toc328680892 \h 4 HYPERLINK \l _Toc328680893 2.1 基本定义 PAGEREF _Toc328680893 \h 4 HYPERLINK \l _Toc328680894 2.1.2 DFA的概念 PAGEREF _Toc328680894 \h 5 HYPERLINK \l _Toc328680895 2.1.3 NFA与DFA的矩阵表示 PAGEREF _Toc328680895 \h 5 HYPERLINK \l _Toc328680896 2.1.4 NFA向DFA的转换的思路 PAGEREF _Toc328680896 \h 6 HYPERLINK \l _Toc328680897 3 DFA的化简 PAGEREF _Toc328680897 \h 7 HYPERLINK \l _Toc328680898 3.1 化简的理论基础 PAGEREF _Toc328680898 \h 7 HYPERLINK \l _Toc328680899 3.2 化简的基本思想 PAGEREF _Toc328680899 \h 7 HYPERLINK \l _Toc328680900 3.3 化简的代码实现 PAGEREF _Toc328680900 \h 7 HYPERLINK \l _Toc328680901 4 程序设计 PAGEREF _Toc328680901 \h 14 HYPERLINK \l _Toc328680902 4.1 程序分析 PAGEREF _Toc328680902 \h 14 HYPERLINK \l _Toc328680903 4.1.1 流程图 PAGEREF _Toc328680903 \h 14 HYPERLINK \l _Toc328680904 4.1.2 子集构造法 PAGEREF _Toc328680904 \h 16 HYPERLINK \l _Toc328680905 4.2 具体的转换过程 PAGEREF _Toc328680905 \h 18 1 前言 1.1 选题的依据和必要性 由于很多计算机系统都配有多个高级语言的编译程序,对有些高级语言甚至配置了几个不同性质的编译程序。从功能上看,一个编译程序就是一个语言翻译程序。语言翻译程序把源语言书

文档评论(0)

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

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

1亿VIP精品文档

相关文档