不确定有限状态自动机的确定化

上传人:痛*** 文档编号:68148897 上传时间:2022-04-01 格式:DOC 页数:11 大小:95.50KB
收藏 版权申诉 举报 下载
不确定有限状态自动机的确定化_第1页
第1页 / 共11页
不确定有限状态自动机的确定化_第2页
第2页 / 共11页
不确定有限状态自动机的确定化_第3页
第3页 / 共11页
资源描述:

《不确定有限状态自动机的确定化》由会员分享,可在线阅读,更多相关《不确定有限状态自动机的确定化(11页珍藏版)》请在装配图网上搜索。

1、编译原理实验报告实验名称 不确定有限状态自动机的确定化 实验时间 院系 计算机科学与技术学院 班级 学号 姓名 1.试验目的输入: 非确定有限(穷)状态自动机。输出: 确定化的有限(穷)状态自动机2.实验原理一个确定的有限自动机(DFA)M可以定义为一个五元组,M(K,F,S,Z),其中:(1) K是一个有穷非空集,集合中的每个元素称为一个状态;(2) 是一个有穷字母表,中的每个元素称为一个输入符号;(3) F是一个从KK的单值转换函数,即F(R,a)Q,(R,QK)表示当前状态为R,如果输入字符a,则转到状态Q,状态Q称为状态R的后继状态;(4) SK,是惟一的初态;(5) ZK,是一个终态

2、集。由定义可见,确定有限自动机只有惟一的一个初态,但可以有多个终态,每个状态对字母表中的任一输入符号,最多只有一个后继状态。 对于DFA M,若存在一条从某个初态结点到某一个终态结点的通路,则称这条通路上的所有弧的标记符连接形成的字符串可为DFA M所接受。若M的初态结点同时又是终态结点,则称可为M所接受(或识别),DFA M所能接受的全部字符串(字)组成的集合记作L(M)。 一个不确定有限自动机(NFA)M可以定义为一个五元组,M(K,F,S,Z),其中:(1) k是一个有穷非空集,集合中的每个元素称为一个状态;(2) 是一个有穷字母表,中的每个元素称为一个输入符号;(3) F是一个从KK的

3、子集的转换函数;(4) SK,是一个非空的初态集;(5) ZK,是一个终态集。由定义可见,不确定有限自动机NFA与确定有限自动机DFA的主要区别是:(1)NFA的初始状态S为一个状态集,即允许有多个初始状态;(2)NFA中允许状态在某输出边上有相同的符号,即对同一个输入符号可以有多个后继状态。即DFA中的F是单值函数,而NFA中的F是多值函数。因此,可以将确定有限自动机DFA看作是不确定有限自动机NFA的特例。和DFA一样,NFA也可以用矩阵和状态转换图来表示。对于NFA M,若存在一条从某个初态结点到某一个终态结点的通路,则称这条通路上的所有弧的标记(除外)连接形成的字符串可为M所接受。NF

4、A M所能接受的全部字符串(字)组成的集合记作L(M)。由于DFA是NFA的特例,所以能被DFA所接受的符号串必能被NFA所接受。设M1和M2是同一个字母集上的有限自动机,若L(M1)L(M2),则称有限自动机M1和M2等价。由以上定义可知,若两个自动机能够接受相同的语言,则称这两个自动机等价。DFA是NFA的特例,因此对于每一个NFA M1总存在一个DFA M2,使得L(M1)L(M2)。即一个不确定有限自动机能接受的语言总可以找到一个等价的确定有限自动机来接受该语言。NFA确定化为DFA同一个字符串可以由多条通路产生,而在实际应用中,作为描述控制过程的自动机,通常都是确定有限自动机DFA,

5、因此这就需要将不确定有限自动机转换成等价的确定有限自动机,这个过程称为不确定有限自动机的确定化,即NFA确定化为DFA。下面介绍一种NFA的确定化算法,这种算法称为子集法:(1) 若NFA的全部初态为S1,S2,Sn,则令DFA的初态为:SS1,S2,Sn,其中方括号用来表示若干个状态构成的某一状态。(2) 设DFA的状态集K中有一状态为Si,Si+1,Sj,若对某符号a,在NFA中有F( Si,Si+1,Sj ,a)= Si,Si+1,Sk 则令F( Si,Si+1,Sj ,a)= Si,Si+1,Sk 为DFA的一个转换函数。若 Si,Si+1,Sk 不在K中,则将其作为新的状态加入到K中

6、。(3) 重复第2步,直到K中不再有新的状态加入为止。(4) 上面得到的所有状态构成DFA的状态集K,转换函数构成DFA的F,DFA的字母表仍然是NFA的字母表。(5) DFA中凡是含有NFA终态的状态都是DFA的终态。对于上述NFA确定化算法子集法,还可以采用另一种操作性更强的描述方式,下面我们给出其详细描述。首先给出两个相关定义。 假设I是NFA M状态集K的一个子集(即IK),则定义-closure(I)为:(1) 若QI,则Q-closure(I);(2) 若QI,则从Q出发经过任意条弧而能到达的任何状态Q,则Q-closure(I)。状态集-closure(I)称为状态I的闭包。假设

7、NFA M(K,F,S,Z),若IK,a,则定义Ia-closure(J),其中J是所有从-closure(I)出发,经过一条a弧而到达的状态集。NFA确定化的实质是以原有状态集上的子集作为DFA上的一个状态,将原状态间的转换为该子集间的转换,从而把不确定有限自动机确定化。经过确定化后,状态数可能增加,而且可能出现一些等价状态,这时就需要简化。3.实验内容输入: 非确定有限(穷)状态自动机。输出: 确定化的有限(穷)状态自动机4.实验心得5.实验代码与结果#include #include #include using namespace std; #define max 100 struct

8、 edge string first;/边的初始结点 string change;/边的条件 string last;/边的终点 ; int N;/NFA的边数 vector value; string closure(string a,edge *b) int i,j; for(i=0;ia.length();i+) for(j=0;jN;j+) if(bj.first0=ai&bj.change=&) a=a+bj.last0; return a; string move(string jihe,char ch,edge *b) int i,j; string s=; for(i=0;ij

9、ihe.length();i+) for(j=0;jN;j+) if(bj.first0=jihei&bj.change0=ch) s=s+bj.last; return s; string sort(string t) int k,i,j; char tt; for(i=0;it.length()-1;i+) k=i; for(j=i+1;jt.length();j+) if(tjtk)k=j; tt=tk;tk=ti;ti=tt; return t; void main() int i,j,x=0,h,length,m,d=0; string Change; string First,La

10、st;/初态,终态, string Tmax,ss; edge *b=new edgemax; cout请输入各边信息:起点 条件(空用&表示) 终点,以输入#结束。endl; for(i=0;ibi.first; if(bi.first=#)break; else cinbi.changebi.last; N=i; cout请输入该NFA的初态及终态:FirstLast; cout请输入此NFA状态中的输入符号即边上的条件:Change; Tx=closure(First,b); Tx=sort(Tx); value.push_back(0); i=0; while(valuei=0&val

11、ue.size() valuei=1; for(j=0;jChange.length();j+) ss=; ss=move(Ti,Changej,b); length=value.size(); for(h=0;hlength;h+) if(Th=sort(closure(ss,b)break; if(h=length) T+x=sort(closure(ss,b); value.push_back(0); i+; edge *DFA=new edgemax; for(i=0;i=x;i+)/构造DFA的各边 for(j=0;jChange.length();j+) DFAd.first=Ti

12、; DFAd.change=Changej; ss=; ss=sort(closure(move(Ti,Changej,b),b); for(m=0;m=x;m+) if(ss=Tm)DFAd+.last=Tm; cout此NFA构造的DFA的各边信息如下:endl起点 条件 终点endl; for(i=0;id;i+) for(m=0;m=x;m+) if(DFAi.first=Tm)coutm DFAi.change; for(m=0;m=x;m+) if(DFAi.last=Tm)cout mendl; cout该DFA的初态为:; for(m=0;m=x;m+) for(j=0;jTm.length();j+) ss=Tm; if(ssj=First0)coutmendl; cout该DFA的终态为:; for(m=0;m=x;m+) for(j=0;jTm.length();j+) ss=Tm; if(ssj=Last0)coutm ; coutendl; system(pause);

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!