如何将 不确定的有穷自动机(NFA) 转化为 确定的有穷自动机(DFA)

一、从NFA到DFA的转换

例如下图:

DFA的每个状态都是一个由NFA中的状态构成的集合,即NFA状态集合的一个子集

r =aa*bb*cc*

二、从带有ε-边的NFA到DFA的转换

r=0*1*2*

三、子集构造法( subset construction)

? 输入:NFA N
? 输出:接收同样语言的DFA D
? 方法:一开始,ε-closure ( s0 )是Dstates 中的唯一状态,且它未加标记;

while(在Dstates中有一个未标记状态T )
{
    给T加上标记;
    for(每个输入符号a)
    {
        U = ε-closure(move(T, a));
        if ( U不在Dstates中)
            将U加入到Dstates中,且不加标记;
        Dtran[T, a]=U ;
    }
} 

四、计算 ε-closure (T )

将T的所有状态压入stack中;将ε-closure  (T )初始化为 T ;

 while(stack非空)
{
  将栈顶元素 t 给弹出栈中;
  for(每个满足如下条件的u :从t出发有一个标号为ε的转换到达状态u)
     if ( u不在ε-closure  (T )中)
    {
      将u加入到ε-closure  (T )中;将u压入栈中;
    }
}

原文地址:https://www.cnblogs.com/AndyEvans/p/10241031.html

时间: 2024-10-06 13:18:45

如何将 不确定的有穷自动机(NFA) 转化为 确定的有穷自动机(DFA)的相关文章

有穷自动机自动转化

#include<string.h> #include<stdio.h> #include<stdlib.h> int main() { char p[30][30]; char q[30][30]; int line=0; int n; int i,j; int count=0; int k,t=0; int flag=0; int l,m=0; char VN[30]={'\0'}; char VT[30]={'\0'}; printf("请输入规则个数&

有穷自动机(NFA、DFA)&amp;正规文法&amp;正规式之间的相互转化构造方法

在编译原理(第三版清华大学出版社出版)中第三章的词法分析中,3.4.3.5.3.6小节中分别讲解了 1.什么是NFA(不确定的有穷自动机)和DFA(确定的有穷自动机) 2.如何将  不确定的有穷自动机(NFA)  转化为  确定的有穷自动机(DFA); 3.如何化简DFA; 4.正规式和有穷自动机的等价性(根据给出的正规式构造有穷自动机); 5.正规文法和有穷自动机的等价性(根据给出的正规式构建有穷自动机): 个人在开始学习这一章节的时候,课上听得有些迷惑,并且看书也是感觉没有头绪,后来花了一些

(1)从正则表达式到有穷自动机,识别字符串(算法思想及代码实现)

正则表达式: 正则表达式是当前主流的字符串识别机制之一,另外一种是文法识别. 和文法相比,正则表达式具有构造相对简单,运行效率较高的特点,所以一般的字符串识别会使用正则表达式. 正则表达式有三种主要运算符是我们在构造词法分析器生成器LEX需要用到的:*.|.连接 *代表闭包运算,假如有一个字符串a,那么a*就代表由任意个字符串a组合成的字符串,包括空串(0个字符串a组合成的字符串),如 *={空串,a,aa,aaa.....} |代表或运算,不同于*闭包运算,|是针对两个字符串的,假如有两个字符

NFA引擎匹配原理

1       为什么要了解引擎匹配原理 一个个音符杂乱无章的组合在一起,弹奏出的或许就是噪音,同样的音符经过作曲家的手,就可以谱出非常动听的乐曲,一个演奏者同样可以照着乐谱奏出动听的乐曲,但他/她或许不知道该如何去改变音符的组合,使得乐曲更动听. 作为正则的使用者也一样,不懂正则引擎原理的情况下,同样可以写出满足需求的正则,但是不知道原理,却很难写出高效且没有隐患的正则.所以对于经常使用正则,或是有兴趣深入学习正则的人,还是有必要了解一下正则引擎的匹配原理的. 2       正则表达式引擎

js 正则学习小记之NFA引擎

之前一直认为自己正则还不错,在看 次碳酸钴,Barret Lee 等大神都把正则玩的出神入化后发现我只是个战五渣.  求抱大腿,求大神调教. 之前大致有个印象,正则有很多种引擎,但我根本不知道有哪些引擎. 今天在读<精通正则表达式>才发现有Traditional NFA,POSIX NFA 和 DFA (具体自己百度下吧).可用了这么久的正则,还不知道 js 属于哪一种呢.在<精通正则表达式>里有个简单是方法检测属于哪一种. 用 /nfa|nfa not/ 去匹配 "nf

构造可配置词法语法分析器生成器(上)

本文为笔者原创,转载请注明出处 http://blog.csdn.net/xinghongduo 前言 源程序在被编译为目标程序需要经过如下6个过程:词法分析,语法分析,语义分析,中间代码生成,代码优化,目标代码生成.词法分析和语法分析是编译过程的初始阶段,是编译器的重要组成部分,早期相关理论和工具缺乏的环境下,编写词法语法分析器是很繁琐的事情.上世纪70年代,贝尔实验室的M. E. Lesk,E. Schmidt和Stephen C. Johnson分别为Unix系统编写了词法分析器生成器Le

正则引擎在数据包匹配中的工程分析

匹配 常见的通用匹配算法有字符串匹配和正则匹配.字符串匹配常见的算法有Boyer-Moore算法.orspool算法.unday算法.MP算法.R算法.AC自动机.Boyer-Moore.Horspool.Sunday算法都是基于后缀数组的匹配算法,区别在于移动的方式不一样.MP是前缀匹配算法,R算法是hash匹配,AC自动机可以同时匹配多个pattern.正则匹配有两种NFA和DFA,都是基于有穷自动机.NFA支持回朔,DFA的效率比NFA高很多,但支持的情况受限. 正则引擎 正则引擎包括NF

正则表达式前端使用手册

导读 你有没有在搜索文本的时候绞尽脑汁, 试了一个又一个表达式, 还是不行. 你有没有在表单验证的时候, 只是做做样子(只要不为空就好), 然后烧香拜佛, 虔诚祈祷, 千万不要出错. 你有没有在使用sed 和 grep 命令的时候, 感觉莫名其妙, 明明应该支持的元字符, 却就是匹配不到. 甚至, 你压根没遇到过上述情况, 你只是一遍又一遍的调用 replace 而已 (把非搜索文本全部替换为空, 然后就只剩搜索文本了), 面对别人家的简洁高效的语句, 你只能在心中呐喊, replace 大法好

编译原理--01 复习大纲(清华大学出版社第3版)

前言 目前以手中这本清华大学出版社出版的编译原理(第3版,张素琴等编著)作为复习总结,因为考试都是大题,一部分概念会被忽略.所有内容都需要通过举例和推导来帮助加深理解,优先为过几天的考试服务.该文实现了教材中那些特别复杂的推导符号,并且这几天会加紧持续更新. 第2章 文法和语言 符号和符号串 空符号串用\(\varepsilon\)表示,长度为0 若 \(\Sigma=\{0,1\}\) ,则 \(\Sigma^*=\{\varepsilon,0,1,00,11,000,001,...\}\),