Python 中 {ab, abc}* 的非确定性有限自动机

问题描述

我一直在尝试绘制这个非确定性有限自动机:

语言{ab,abc}*的状态数不超过3的NFA,我得到了下图的解决方案:

NFA diagram

问题似乎出在代码逻辑上,因为我的代码总是打印“rejected”。如果有人可以提供一些有关如何编写此算法的提示,我将不胜感激。

print("Insert below the string: ")
string = str(input())


def state_q0(string):
    if len(string) == 0:
        print("string not accepted")
    else:
        if string[0] == "a":
            state_q1(string[1:])
        elif string[0] == "b":
            print("rejected")


def state_q1(string):
    if len(string) == 0:
        print("string not accepted")
    else:
        if string[1] == "b":
            state_q2(string[2:])
        else:
            print("rejected")


def state_q2(string):
    if len(string) == 0:
        print("string not accepted")
    else:
        if string[2] == "c":
            print("accepted -> q0")
        elif string[2] == "b":
            print("rejected")


state_q0(string)

解决方法

您应该始终查看字符串的第一个字符,并使用除第一个字符以外的所有内容调用递归调用。

在您的图表中也没有注明,但我假设 q0 是接受状态,因为它对应于 (ab + abc)*

所以按照你的风格(我个人不会使用,但可以):

def q0(s):
    if not s: return "accept"  # Accepting state.
    if s[0] == "a": return q1(s[1:])
    return "reject"

def q1(s):
    if not s: return "reject"
    # NFA,must try both edges.
    if (s[0] == "b" and q0(s[1:]) == "accept" or
        s[0] == "b" and q2(s[1:]) == "accept"):
        return "accept"
    return "reject"

def q2(s):
    if not s: return "reject"
    if s[0] == "c": return q0(s[1:])
    return "reject"

然而,我将如何编写 NFA:

transitions = [
    {"a": {1}},{"b": {0,2}},{"c": {0}}
]
starting_state = 0
accepting_states = {0}

def nfa(w):
    cur_states = {starting_state}
    for c in w:
        if not cur_states: return "reject"
        cur_states = set.union(*
            (transitions[s].get(c,set()) for s in cur_states))
    return "accept" if cur_states & accepting_states else "reject"

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...