编译原理之非确定的自动机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识别的是什么样的语言。

语言为:(a|b)*abb

2.NFA 确定化为 DFA

1.解决多值映射:子集法

1). 上述练习1的NFA

2). 将下图NFA 确定化为 DFA

2.解决空弧:对初态和所有新状态求ε-闭包

1).

    图转换为矩阵:

    状态转换图:

    

    识别语言为:0*(11*2 | 2)2*

2)

    

    图转换为矩阵:

    

    此矩阵相当于

对此矩阵画出状态转换图

    

子集法:

f(q,a)={q1,q2,…,qn},状态集的子集

将{q1,q2,…,qn}看做一个状态A,去记录NFA读入输入符号之后可能达到的所有状态的集合。

步骤:

1).根据NFA构造DFA状态转换矩阵

①确定DFA的字母表,初态(NFA的所有初态集)

②从初态出发,经字母表到达的状态集看成一个新状态

③将新状态添加到DFA状态集

④重复23步骤,直到没有新的DFA状态

2).画出DFA

3).看NFA和DFA识别的符号串是否一致。

原文地址:https://www.cnblogs.com/Rakers1024/p/11771951.html

时间: 2024-08-01 21:51:49

编译原理之非确定的自动机NFA确定化为DFA的相关文章

编译原理:非确定的自动机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识别的是什么样的语言. 解析:   a b 0 {0,1} 0 1 2 2 3 3   状态转换图如下: 识别语言为:(a | b)*abb 2.NFA 确定化为 DFA 1.解决多值映射:子集法 1). 上述练习1的NFA 解析: 根据1的NFA构造DFA状态转换矩阵如

第八次.非确定的自动机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识别的是什么样的语言. 状态转换矩阵   a b 0 0,1 0 1 Φ 2 2 Φ 3 3 Φ Φ 状态转换图 该NFA识别的语言:  L(M)= (a | b) * abb 2.NFA 确定化为 DFA 1.解决多值映射:子集法 1). 上述练习1的NFA 状态转换矩

编译原理学习(9)非确定的自动机NFA确定化为DFA

1.解决多值映射:子集法 1). 发给大家的图1 2). P64页练习3   2.解决空弧:对初态和所有新状态求ε-闭包 1). 发给大家的图2 2).P50图3.6 原文地址:https://www.cnblogs.com/xyqzzz/p/11773747.html

非确定的自动机NFA确定化为DFA

1.解决多值映射:子集法 1). 发给大家的图1 2). P64页练习3 2.解决空弧:对初态和所有新状态求ε-闭包 1). 发给大家的图2 2).P50图3.6 原文地址:https://www.cnblogs.com/ray064/p/11757824.html

非确定的自动机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识别的是什么样的语言. 2.NFA 确定化为 DFA 1.解决多值映射:子集法 1). 上述练习1的NFA 2). P64页练习3 2.解决空弧:对初态和所有新状态求ε-闭包 1). 发给大家的图2 2).P50图3.6 原文地址:https://www.cnblogs.

编译原理:正规式转变成NFA算法

import java.util.ArrayList; import java.util.Map; import java.util.TreeMap; class Edge{ private int u, v; private char key; public Edge(int u, int v, char key) { super(); this.u = u; this.v = v; this.key = key; } @Override public String toString() {

编译原理-NFA构造DFA

本题摘自北邮的编译原理与技术. 首先,根据此图构造状态转换表 表中第一列第一行表示从第一个符号B通过任意个空转换能到达的节点,Ia表示由此行的状态数组({B,5,1}可以看作0状态)经过一个a可以到达的节点,同理,Ib表示由状态数组经过一个b可以到达的节点. 当然,有些人可能觉得{B,5,1}和{5,1,3}看作两个状态不合理,他们之间不是有交集嘛,实际上他们之间并无交集,因为输入a后,{B,5,1}能到达的新节点是3,之所以要写成{5,1,3},可能是要兼顾逻辑吧>_> 再仔细观察第一行,既

编译原理:正规式、正规文法与自动机

1.正规式转换到正规文法 对任意正规式R选择一个非终结符Z生成规则Z→R 1.对形如A→ab的规则,转换成A→aB,B→b 2.将形如A→a|b的规则,转换成A→a,A→b(A→a|b) 3.将形如A→a*b的规则,转换成A→aA,A→b 将形如A→ba*的规则,转换成A→Aa,A→b 不断利用上述规则进行转换,直到每条规则最多含有一个终结符为止. 1(0|1)*101 解析: S-> A1 A-> B0 B-> C1 C-> 1(0|1)* -> 1|C0|C1 (a|b)

了解编译原理-笔记小结

这是之前学习编译原理过程中做下的笔记. 因能力有限,在很多地方都理解不到位,特别是对于词法分析与语法分析的过程感觉特别晦涩. 分享这个笔记也是为了自己做个总结,算是一个小的提纲吧,都没怎么深入解析编译的过程. 等以后领悟更多了再作补充吧. 希望各路人士能多加指点,谢谢. 词法分析 作用:将输入转换为一个一个的token,而其用一串整数来表示. 协作:只有当解析器需要的时候才会请求词法分析器,继续扫描输入流,在这个过程中将不断生成符号表. 实现:在通常的编程语言中,相对于不确定的有限自动机(NFA