c++ - Myhill-Nerode 定理矩阵到自动机

标签 c++ automata dfa

我已经用 C++ 成功实现了 Myhill-Nerode 定理。当它完成最小化给定自动机时,给出一个矩阵作为答案。

在此页面上使用自动机:http://web.stcloudstate.edu/pkjha/CSCI502/Minimize.html ,我有最终矩阵(这是给定矩阵的完整矩阵,而不是下三角矩阵):

- x x x x x x x x 
x - - x x x x x x 
x - - x x x x x x 
x x x - - - - x x 
x x x - - - - x x 
x x x - - - - x x 
x x x - - - - x x 
x x x x x x x - - 
x x x x x x x - -

也就是说第1,2,4,8行都是不同的状态,第(1),(2,3),(4,5,6,7),(8,9)行可以分组进入相同的状态。

我正在使用一个类来表示根据此结构的自动机的每个状态:

class state{
    public:
        string state_name;        
        vector<string> transitions; 
        bool final;                
        bool start;            
    public:
        state(string,vector<string>,bool,bool);
};

其中,state name 是我当前状态的名称(A,B,C,D,state1,...),transitions 是一个字符串 vector ,包含我的自动机可以进入的每个状态的名称,final 是指示我的状态是否为接受状态的 bool 值,开始是指示我的状态是否为开始状态的 bool 值。

例如,对于给定自动机的节点 q0,其结构类似于:

state_name: q0
transitions: (q1,q2) <- always following the alphabet order
final: false
start: true

我的问题是:我需要按照给定的结构将此矩阵转换为自动机结构。我可以很容易地识别开始/结束状态,因为我有原始的自动机信息,而且我可以很容易地识别每个组。

我在矩阵中无法弄清楚的是组之间的转换。有什么建议吗?

最佳答案

每个州都是某个组的成员,对于每个组,您都有一个组中的州列表。要找到组 G1 的转换,请选择组中的状态 S1 之一,获取 S1 的转换,并为每个目标状态 S2 找到相应的组 G2。您获得的所有 G2 的集合构成了 G1 的转换。 (注意,因为G1中的所有状态都是等价的,所以只需要考虑一个代表状态S1即可。)

关于c++ - Myhill-Nerode 定理矩阵到自动机,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29989213/

相关文章:

parsing - 左递归语法中先发现后跟随的混淆

regular-language - 使用泵送引理的条件 3 证明不规则性

c++ - 将 std::get 与枚举类一起使用时需要 static_cast

c++ - 并行多次调用一个函数

c++ - 根据条件 C++ 从 vector 中复制元素

string - Knuth-Morris-Pratt 算法中的 DFA 构造

regular-language - 常规语言的抽动引理

intersection - 估计 DFA 中的状态数(交集)

c++ - 我怎样才能在 OpenGL 片段着色器中制作这个球形渐变?

c++ - 访问其他应用程序的内存 C++