自动机-python实现

使用python画自动机的图,并得到自动机从初始状态到达终止状态所有可接受序列

class Automaton:
    def __init__(self, transitions, start, accepting):
        self.transitions = transitions
        self.start = start
        self.accepting = accepting

    def is_accepting(self, state):
        return state in self.accepting

    def get_next_states(self, state, char):
        next_states = []
        for s, c, t in self.transitions:
            if s == state and c == char:
                next_states.append(t)
        return next_states

    def get_all_sequences(self):
        sequences = []
        stack = [(self.start, "")]
        while stack:
            state, seq = stack.pop()
            if self.is_accepting(state):
                sequences.append(seq)
            for char in set(t[1] for t in self.transitions if t[0] == state):
                next_states = self.get_next_states(state, char)
                for next_state in next_states:
                    stack.append((next_state, seq + char))
        return sequences

    def draw(self):
        from graphviz import Digraph

        dot = Digraph()
        dot.node(str(self.start), shape="doublecircle" if self.is_accepting(self.start) else "circle")
        for state in self.transitions:
            dot.node(str(state[0]), shape="doublecircle" if self.is_accepting(state[0]) else "circle")
            dot.node(str(state[2]), shape="doublecircle" if self.is_accepting(state[2]) else "circle")
            dot.edge(str(state[0]), str(state[2]), label=state[1])
        dot.render("automaton.gv", view=True)
transitions = [(0, 'a', 1), (1, 'b', 2), (1, 'c', 3), (2, 'd', 4), (3, 'e', 4)]
start = 0
accepting = {4}
automaton = Automaton(transitions, start, accepting)
automaton.draw()
sequences = automaton.get_all_sequences()
print("All accepting sequences:", sequences)

结果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拒绝拖延哎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值