编译原理实验四.

上传人:我** 文档编号:114445260 上传时间:2019-11-11 格式:DOC 页数:12 大小:215KB
返回 下载 相关 举报
编译原理实验四._第1页
第1页 / 共12页
编译原理实验四._第2页
第2页 / 共12页
编译原理实验四._第3页
第3页 / 共12页
编译原理实验四._第4页
第4页 / 共12页
编译原理实验四._第5页
第5页 / 共12页
点击查看更多>>
资源描述

《编译原理实验四.》由会员分享,可在线阅读,更多相关《编译原理实验四.(12页珍藏版)》请在金锄头文库上搜索。

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

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

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

4、称这条通路上的所有弧的标记(除外)连接形成的字符串可为M所接受。NFA 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同一个字符串可以由多条通路产生,而在

5、实际应用中,作为描述控制过程的自动机,通常都是确定有限自动机DFA,因此这就需要将不确定有限自动机转换成等价的确定有限自动机,这个过程称为不确定有限自动机的确定化,即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的一个转换函

6、数。若 Si,Si+1,Sk 不在K中,则将其作为新的状态加入到K中。(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-cl

7、osure(I)。状态集-closure(I)称为状态I的闭包。假设NFA M(K,F,S,Z),若IK,a,则定义Ia-closure(J),其中J是所有从-closure(I)出发,经过一条a弧而到达的状态集。NFA确定化的实质是以原有状态集上的子集作为DFA上的一个状态,将原状态间的转换为该子集间的转换,从而把不确定有限自动机确定化。经过确定化后,状态数可能增加,而且可能出现一些等价状态,这时就需要简化。3. 实验内容输入: 非确定有限(穷)状态自动机。 输出: 确定化的有限(穷)状态自动机4. 实验心得此次实验采用了java可视化的界面来编程的,编程的主要思想是:首先构造NFA的状态的

8、子集的算法,再来计算-closure。完成这些子模块的设计后,再通过某一中间模块的总控程序对其调用,最后再由主程序总调用,也就实现了NFA转化为其等价的DFA,接下来就是在实现DFA的化简,最后加以验证,经多次代码的修改成型。通过实验,我可以更好的掌握了NFA到DFA的转化的原理。5. 实验代码与结果5.1实验运行结果截图如下:左侧为输入的每个NFA的每个状态,右侧为显示的结果,显示了子集个数,和由NFA构造的DFA状态。5.2代码:package wy;import java.awt.Graphics;import java.awt.Graphics2D;import java.awt.Im

9、age;import java.awt.Toolkit;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.util.ArrayList;import javax.swing.*;class Node /每一个结点包含的有以该结点为起始的整条边的信息: String data; /本结点值 String condition;/条件值 空符号串用表示 String next;/指向下一个结点的结点值 Node(String d)/终止结点 data=d; condition=null

10、; next=null; Node(String d,String c,String s)/非终止结点 data=d; condition=c; next = s; /下一个结点的值 public class NFA_DFA extends JFramepublic static void main(String args) NFA_DFA nfa_dfa=new NFA_DFA();nfa_dfa.NFA_DFA();public JLabel jl0 = new JLabel(-每条边的信息如下:-);public JLabel jl_start = new JLabel(起点状态:);p

11、ublic JLabel jl_condition = new JLabel(条件:);public JLabel jl_end = new JLabel(终点状态:);public JTextField jtf_start = new JTextField();public JTextField jtf_condition = new JTextField();public JTextField jtf_end = new JTextField();public JButton jbt0 = new JButton(确定);public JLabel jl_start0 = new JLab

12、el(初态:);public JLabel jl_end0 = new JLabel(终态:);public JButton jbt1 = new JButton(确定);public JTextField jtf_start0 = new JTextField();public JTextField jtf_end0 = new JTextField();public JTextArea jta_display = new JTextArea();public JScrollPane sta1 = new JScrollPane(jta_display);public JButton jbt

13、_result = new JButton(结果显示);public JTextArea jta_display1 = new JTextArea();public JScrollPane sta2 = new JScrollPane(jta_display1);public ArrayList node = new ArrayList();/非终止结点public ArrayList node_end = new ArrayList();/终止结点public ArrayList condition = new ArrayList();/条件符号public ArrayListArrayList C=new ArrayListArrayList();/子集族Cpublic ArrayList CC=new ArrayList();/重命名的Cpublic String start0;/初态值public void NFA_DFA()this.setTitle(NFA转换为DFA-WY);this.setContentPane(new MyPanel5();this.setLayout(null);this.setSize(700, 700);jl_start0.setBounds(150, 35, 70, 30);add(jl_start0);jtf_s

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号