ImageVerifierCode 换一换
格式:DOCX , 页数:22 ,大小:54.27KB ,
资源ID:134157      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/134157.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(NFA转化为DFA的转换算法及实现.docx)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

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

1、编译原理课程实践报告设计名称:NFA 转化为 DFA 的转换算法及实现二级学院: 数学与计算机科学学院专业: 计算机科学与技术班级: 计科本 091 班姓名: 学号: 指导老师: 日期: 2012 年 6 月 28 日摘要有穷自动机分为确定的有穷自动机(DFA)和不确定的有穷自动机(NFA) 两类。两者各有特点、作用于不同的地方,因此需要进行转化。NFA转化为DFA 的理论在词法构造乃至整个编译器构造过程中起着至关重要的作用,同时它们被广泛应用于计算机科学的各个领域,它们与计算机其它学科之间也有着很密切的关系。本文主要介绍基于编译器构造技术中的由NFA转化为DFA的算法设计和实现技术:主要包括

2、NFA转化为与其等价的DFA所使用的子集构造算法以及把DFA化简的算法,实现词法分析,最后使用Visual C+语言加以实现。NFA转化为与其等价的DFA需分两步进行:1、构造NFA的状态的子集的算法;2、计算-closure。完成这些子模块的设计后,再通过某一中间模块的总控程序对其调用,最后再由主程序总调用,也就实现了NFA转化为其等价的DFA,接下来就是以分割法的思想为指导实现DFA的化简,最后并以实例加以说明。关键词:有穷自动机;NFA ;DFA; 转化 ; 化简22目录1 前言31.1 选题的依据和必要性31.2 课题意义32 NFA 转化为 DFA 的算法及实现42.1 基本定义42

3、.1.2 DFA 的概念52.1.3 NFA 与 DFA 的矩阵表示52.1.4 NFA 向 DFA 的转换的思路63 DFA 的化简73.1 化简的理论基础73.2 化简的基本思想73.3 化简的代码实现74 程序设计144.1 程序分析144.1.1 流程图144.1.2 子集构造法164.2 具体的转换过程181 前 言1.1 选题的依据和必要性由于很多计算机系统都配有多个高级语言的编译程序,对有些高级语言甚至配置了几个不同性质的编译程序。从功能上看,一个编译程序就是一个语言翻译程序。语言翻译程序把源语言书写的程序翻译成目标语言的等价程序。经过编译程序的设计可以大大提高学生的编程能力。编

4、译程序的工作过程通常是词法分析、语法分析、语义分析、代码生成、代码优化1。由于现在有很多词法分析程序工具都是基于有穷自动机的,而词法分析又是语法分析的基础2,所以我们有必要进行有穷自动机的确定化和最小化。1.2 课题意义编译程序的这些过程的执行先后构成了编译程序的逻辑结构3。有穷自动机(也称有限自动机)作为一种识别装置,它能准确地识别正规集,即识别正规文法所定义的语言和正规式所表示的集合,引入有穷自动机这个理论,正是为词法分析程序的自动构造寻找特殊的方法和工具4。NFA转化为DFA的理论在词法构造至整个编译器构造过程中起着至关重要的作用,同时它们被广泛应用于计算机科学的各个领域,它们与计算机其

5、它学科也有着密切的联系。2 NFA转化为DFA的算法及实现编译原理是计算机专业的一门重要专业课,旨在介绍编译程序构造的一般 原理和基本方法。内容包括语言和文法、词法分析、语法分析、语法制导翻译、中间代码生成、存储管理、代码优化和目标代码生成。进行NFA转换为DFA的词 法分析和语法分析,首先要对目标对象有有所了解,这就需要对NFA、DFA进一 步了解。2.1 基本定义NFA,也称不确定的有穷自动机,是由一个五元式定义的数学模型,特点是它的不确定性,即在当前状态下,读入同一个字符,可能有多个下一状态。DFA,也称确定的有穷自动机,也是由一个五元式定义的数学模型,相对的 特点是它的确定性,即在当前

6、状态下,读入同一个字符,最多有一个后继状态。2.1.1 NFA 的概念NFA(nondeterministic finite-state automata)即非确定有限自动机,一个非确定的有限自动机 NFA M是一个五元式:NFAM=(S, , , S0,F)其中S有限状态集输入符号加上 ,即自动机的每个结点所射出的弧可以是 中一个字符或是 .S0初态集F终态集转换函数S 2S1S10Z1P(2S -S 的幂集S 的子集构成的集合) 状态转换图如图2.1.1:0,1图2.1.1NFA状态转换图2.1.2 DFA的概念DFA(deterministic finite-state automata

7、)即确定有限自动机,一个确定的有限自动机 DFA M 是一个五元式:M=(S, ,, S0, Z)其中:S有限状态集 输入字母表 映射函数(也称状态转换函数)aaPa,PbaZbPb图2.1.2DFA状态转换图2.1.3 NFA与DFA的矩阵表示一个NFA或者DFA还可以用一个矩阵5表示,矩阵也可以说是状态转换表, 它的优点是可以快速访问给定的状态在给定的输入字符时能转换到的状态集。矩阵,每个状态一行,每个输入符号和(如果有需要的)各占一列,表的第i 行中与输入符号a对应的表项是一个状态集合,表示NFA或者DFA在状态i输入a 时所能到达的状态集合(DFA的集合唯一),即(i,a)6。(7)如

8、图2.1.1可用表2.3.1.表示:表2.3.1 NFA状态转换表输入状态01SPS,ZPZZPP如图2.1.2可用表2.3.2表示:表2.3.2 DFA状态转换表输入状态ab0121322133332.1.4 NFA向DFA的转换的思路从NFA的矩阵表示中可以看出,表项通常是一状态的集合,而在DFA的矩阵表示中,表项是一个状态,NFA到相应的DFA的构造的基本思路是:DFA的每一个状态对应NFA的一组状态DFA使用它的状态记录在NFA读入一个输入符号后可能达到的所有状态4。2.2 NFA 和 DFA 之间的联系在非确定的有限自动机 NFA 中,由于某些状态的转移需从若干个可能的后续状态中进行

9、选择,故一个 NFA 对符号串的识别就必然是一个试探的过程。这种不确定性给识别过程带来的反复,无疑会影响到 FA 的工作效率。而 DFA 则是确定的,将 NFA 转化为 DFA 将大大提高工作效率,因此将 NFA 转化为 DFA 是有其一定必要的。3 DFA的化简得到新的DFA之后,并没有完成任务,因为通过NFA转化成DFA不一定是最简的,也就是说,有多余的状态可以被删除,而我们需要的是得到一个唯一的最简的DFA12,也就是说,NFA转化为DFA之后,还需要化简,也就是最小化。3.1 化简的理论基础DFA的化简是指:寻找一个状态数最少的DFAM,使得L(M)=L(M)。化简的方法是消去DFAM

10、中的多余状态(或无用状态),合并等价状态。DFA中的多余状态是指这样的状态:从开始状态出发,读入任何输入串都不能到达的那个状态;或者从这个状态没有通路到达终态。两个状态S和T等价是指:如果从状态S出发能读出某个字W而停于终态,从T出发也能读出同样的字W而停于终态;反之,从T出发能读出同样的字W而停于终态,从S出发也能读出某个字W而停于终态。3.2 化简的基本思想化简DFA的基本思想是指导它的状态分成一些互不相交的子集,每一个子集中的状态都不是等价的,不同子集中的状态可以由某个输入串来区别,最后将不能区别的每个子集用一个状态来做代表13-15,这种方法称为“分割法”。具体过程是:(1) 将M的所

11、有状态分成两个子集终态集和非终态集;(2) 考察每一个子集,若发现某子集中的状态不等价,将其划分为两个集合;(3) 重复第(2)步,继续考察已得到的每一个子集,直到没有任何一个子集需要继续划分为止。这时DFA的状态被分成若干个互不相交的子集。(4) 从每个子集中选出一个状态做代表即可得到最简的DFA。3.3 化简的代码实现#include #include#define MAXS 100 using namespace std;string NODE; /结点集合string CHANGE; /终结符集合int N; /NFA 边数struct edge string first; strin

12、g change; string last;struct chan string ltab;string jiheMAXS;void kong(int a)int i; for(i=0;ia;i+)cout ;/排序void paixu(string &a)int i,j; char b;for(j=0;ja.length();j+) for(i=0;iNODE.find(ai+1)b=ai; ai=ai+1; ai+1=b;void eclouse(char c,string &he,edge b)int k; for(k=0;khe.length() he+=bk.last; eclous

13、e(bk.last0,he,b);void move(chan &he,int m,edge b)int i,j,k,l; k=he.ltab.length(); l=he.jihem.length(); for(i=0;ik;i+) for(j=0;jhe.jihem.length() he.jihem+=bj.last0;for(i=0;il;i+) for(j=0;jhe.jihem.length()he.jihem+=bj.last0;/输出void outputfa(int len,int h,chan *t)int i,j,m; cout I ;for(i=0;ilen;i+) coutICHANGEi ; coutendle

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1