NFA转化为DFA
NFA(不确定的有穷自动机)转化为DFA(确定的有穷自动机)
NFA转换DFA,通常是将带空串的NFA(即:ε-NFA)先转化为不带空串的NFA(即:NFA),然后再转化为DFA。
提示:ε是空串的意思!空串没有任何字符!

这里直接讲将ε-NFA转化为DFA的过程,将NFA转化为DFA的情况类似。
转化的过程总的来说有两大步骤:ε-NFA转化为DFA,以及DFA简化
ε-NFA转化为DFA前件知识
1、对状态图进行改造
增加状态X,Y,使之成为新的唯一的初态和终态,从X引ε弧到原初态节点,从原终态节点引ε弧到Y节点。

2、利用子集法对NFA进行确定化。
- 子集法
子集法:将NFA转化为接受同样语言的DFA。
DFA的每一个状态对应NFA的一组状态;
DFA使用它的状态去记录NFA读入一个符号后可能达到的所有状态

如上图,A对应ε-NFA的0和1状态,A代表的是一组状态。因此,DFA使用它的状态去记录NFA读入一个符号后可能达到的所有状态。
- 构造状态转化表
- ε-closure(ε-闭包)
状态集合I的ε-闭包是一状态集。
①任何状态q∈I,则q∈ε-closure(I)
②任何状态q∈I,则q经任意条ε弧而能到达的状态q'∈ε-closure(I)
比如上图,假设I={0},那么0∈ε-closure(I);并且0经ε弧能到达1状态,因此,1∈ε-closure(I)。即:ε-closure({0})={0,1}。
案例再现
可能前面的理论有些乱,理不清,这里用一个例题演绎如何将ε-NFA转化为DFA。
已知下面的NFA图,求确定后的DFA:

①改造状态图:在起始状态分别加上X、Y状态,连接输入符号为ε。

②状态转换表
| 状态集合 \状态 | 0 | 1 |
|---|---|---|
| A={X,0,2,1} | B={2,3,1} | C={2,1} |
| B={2,3,1} | D={2,4,3,1,Y} | C={2,1} |
| C={2,1} | B={2,3,1} | C={2,1} |
| D={2,4,3,1,Y} | D={2,4,3,1,Y} | C={2,1} |
!提示:A,B,C,D表示状态集合;0,1分别表示状态0和1。第二行第二列表示状态集合A的状态在输入符号0后到达的状态的ε-闭包为B={2,3,1}。
获得改造后的状态图后,我们找到起始状态为X,由于X与0之间是输入的ε符号,所以X与0等价;同理,0与2等价,1与2等价。所以,起始状态有{X,0,2,1},我们给它命名为状态A。
再看第二列,处于起始状态A时,当输入字符为0时到达的状态分别有:2输入0到达2本身;1输入0到达3,因此还有3状态。再看与2等价的状态有:1;与3等价的状态无。因此,输入字符0时到达的状态有{2,3},它的闭包是:{2,3,1}。
第三列同理,处于起始状态A时,当输入字符为1时到达的状态只有2。2的等价状态有1。因此,输入字符1时A到达的状态有{2},它的闭包是{2,1}。
!注意:状态转换表里面填入的是闭包结果。
最后得到的DFA图为:(未简化)

DFA简化
状态S和状态T等价的条件
- 一致性条件:状态S和T必须同时为可接受状态或不可接受状态。
- 蔓延性条件:对于所有符号,状态S和T必须转换到等价的状态里。
DFA简化算法:
1、假定一个集合中的状态都是等价的,首先将DFA的所有状态放在一个集合I中。
2、所有状态分成两个子集——终态集和非终态集。运用判定状态等价原则分别对两个子集的状态进行分析和划分。若发现某个状态与其他状态不等价,则将其作为一个新的状态子集,如果无法区分,则放在同一子集中。
3、从每个子集中选出一个状态做代表,即可构成简化的DFA。
4、含有原来初态的子集仍为初态,各终态的子集仍为终态。
案例再现
将上面未简化的DFA图简化:
①I = {A,B,C,D}
②拆分终态集和非终态集:
非终态集{A,B,C}+终态集{D}
③对{A,B,C}继续拆分:
A输入0后到达B,而B⊆{A,B,C},故A不能拆分;
再看B,B输入0后到达D,而D¢{A,B,C},故B可以拆分;
再看C,C输入0后到达B,B⊆{A,B,C},故C也不能拆分。
综上:{A,B,C}可拆分为{A,C}+{B}。
④对{A,C}继续拆分:
A输入1时到达C,而C⊆{A,C},故A不可拆分;
再看C,C输入1时到达C状态,而C⊆{A,C},故C也不可拆分。
⑤综合起来,上面未简化的DFA图简化后得到的状态应该是:{A,C}+{B}+{D}。
!注意:同一个{}大括号里面的状态是等价的,因此,画图时选其一即可。
简化后的DFA图为:

Are you got it?(你学会了吗?)
NFA转化为DFA的更多相关文章
- 非确定的自动机NFA确定化为DFA
摘要: 在编译系统中,词法分析阶段是整个编译系统的基础.对于单词的识别,有限自动机FA是一种十分有效的工具.有限自动机由其映射f是否为单值而分为确定的有限自动机DFA和非确定的有限自动机NFA.在非确 ...
- 第八次作业-非确定的自动机NFA确定化为DFA
NFA 确定化为 DFA 子集法: f(q,a)={q1,q2,…,qn},状态集的子集 将{q1,q2,…,qn}看做一个状态A,去记录NFA读入输入符号之后可能达到的所有状态的集合. 步骤: 1. ...
- 编译原理之非确定的自动机NFA确定化为DFA
1.设有 NFA M=( {0,1,2,3}, {a,b},f,0,{3} ),其中 f(0,a)={0,1} f(0,b)={0} f(1,b)={2} f(2,b)={3} 画出状态转换矩阵 ...
- 作业八——非确定的自动机NFA确定化为DFA
NFA 确定化为 DFA 子集法: f(q,a)={q1,q2,…,qn},状态集的子集 将{q1,q2,…,qn}看做一个状态A,去记录NFA读入输入符号之后可能达到的所有状态的集合. 步骤: 1. ...
- 第八次——非确定的自动机NFA确定化为DFA
NFA 确定化为 DFA 子集法: f(q,a)={q1,q2,…,qn},状态集的子集 将{q1,q2,…,qn}看做一个状态A,去记录NFA读入输入符号之后可能达到的所有状态的集合. 步骤: 1. ...
- 编译原理:非确定的自动机NFA确定化为DFA
1.设有 NFA M=( {0,1,2,3}, {a,b},f,0,{3} ),其中 f(0,a)={0,1} f(0,b)={0} f(1,b)={2} f(2,b)={3} 画出状态转换矩阵 ...
- 第八次-非确定的自动机NFA确定化为DFA
提交作业 NFA 确定化为 DFA 子集法: f(q,a)={q1,q2,…,qn},状态集的子集 将{q1,q2,…,qn}看做一个状态A,去记录NFA读入输入符号之后可能达到的所有状态的集合. ...
- 编译原理-NFA转化成DFA
1.假定NFA M=<S,∑,f,S0,F> 对M的状态转换图进行以下改造: ①引进新的初态结点X和终态结点Y, X,Y∈S, 从X到S0中的任意结点连一条ε箭弧, ...
- 正规式转化为DFA
https://www.bilibili.com/video/BV1dj411f7AR?p=50 例题:
随机推荐
- gin框架中使用jwt
生成解析token 如今有很多将身份验证内置到API中的方法 -JSON Web令牌只是其中之一.JSON Web令牌(JWT)作为令牌系统而不是在每次请求时都发送用户名和密码,因此比其他方法(如基本 ...
- 集合框架-工具类-JDK5.0特性-静态导入
1 package cn.itcast.p4.news.demo; 2 3 import java.util.ArrayList; 4 //import java.util.Collections; ...
- 事件驱动架构在 vivo 内容平台的实践
一.什么是事件驱动架构 当下,随着微服务的兴起,容器化技术的发展,以及云原生.serverless 概念的普及,事件驱动再次引起业界的广泛关注. 所谓事件驱动的架构,也就是使用事件来实现跨多个服务的业 ...
- 了解promise、promise对象
Promise 是异步编程的一种解决方案,比传统的解决方案--回调函数和事件--更合理和更强大.它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Promise对象. 所谓Pr ...
- python32day
内容回顾 操作系统的历史 多道操作系统 分时操作系统 实时操作系统 进程 线程 并行和并发 同步和异步 阻塞和非阻塞 今日内容 进程的三状态图 进程的调度算法 给所有进程分配资源或者分配CPU使用权的 ...
- python09day
内容回顾 文件操作初识 三步走: 打开文件open() 文件路径path,编码方式encoding=,mode(默认读) 操作文件(对文件句柄进行操作) 读.写.追加 各四种模式 读:read().r ...
- 前端-Data URI Scheme
了解Data URI scheme,首要要掌握一些URI.URL的基本知识,很多做移动端上开发的同学对这两个基本概念掌握的不够,本文首先会对这两个基本概念做一些简单的介绍. 基本概念 <HTTP ...
- 如何按规定的格式向mysql中导入数据
1.首先我们拿到数据,数据必须按照一定的格式书写的.如用|区分字段,换行区分row 12107 | 心情1 | 今天的心情很不好啊. 12108 | 天气 | 今天天气还行. 12109 | 臭美 | ...
- yum本地源仓库安装报错 被锁定如何解决?
yum安装报错被锁定如何解决 上图!!!!!如图的报错 解决方法: 是不是很简单 智商在地上摩擦~~~
- 线性结构和非线性结构、稀疏数组、队列、链表(LinkedList)
一.线性结构和非线性结构 线性结构: 1)线性绪构作为最常用的数据结构,其特点是数据元素之间存在一对一的线性关系 2)线性结构有两种不同的存储结构,即顺序存储结构和链式存储结构.顺序存储的线性表称为顺 ...