确定有限状态自动机简介
有限状态自动机拥有有限数量的状态,每个状态可以迁移到零个或多个状态,输入字串决定执行哪个状态的迁移。
DFA是理解KMP算法的基础。
关于什么是DFA,可参考链接:有穷自动机DFA&NFA
本篇的主要目的是实现DFA。
实现过程
下面是一个字符串ABABAC
的DFA:
构建DFA过程
实现分析
一. 首先DFA有什么意义呢?它表示了什么?
字符串
A
, 它的DFA是这样的:
如果输入字符串A
, 那么DFA输出 1,
如果输入字符串B
, 那