对于DFA、NFA理解

最近在做深度包检测课题时,需要学一些新的算法:
DFA、NFA,对这两个算法进行一下小的总结:

有穷状态自动机

一听这个名字感觉很高大上,很陌生,不知道是什么意思,但是可以分开来理解。有穷,也就是说这个东西是有穷尽的,不是无限多的。状态自动机(自动机):软件工程的统一建模语言(UML)有状态图,数字逻辑中也有状态转移图。不过这些各种各样的图在本质上都跟状态机没有什么区别。总体的意思就是在有限个输入的情况下,在这些状态中转移并期望最终达到终止状态。有穷状态自动机根据确定性可以分为“确定有穷状态自动机”(DFA - Deterministic finite automaton)和“非确定有穷自动机”(NFA - Non-deterministic finite automaton)。

DFA

确定性有穷状态自动机:在输入一个状态时,只得到一个固定的状态。但往往从正则表达式翻译过来的状态机是ε-NFA,我们需要从ε-NFA通过消除ε边来转变成NFA或者DFA。关于转换在这篇文章里有提到
例如:
这里写图片描述
当输入一个任何一个可以的字符时,都得到一个固定的状态。

NFA

这个里面还有一个小的分支ε-NFA。ε-NFA:我们用ε边来表示一个状态可以不读入字符就跳转到另一个状态 上,ε-NFA就是在NFA中存在这种边的情况,例如:
这里写图片描述
从start状态到end状态,可以不需要读入字符就进行转换。
NFA:“非确定有穷自动机”(NFA - Non-deterministic finite automaton),当输入一个字符或者条件得到一个状态机的集合。
例如:
这里写图片描述
当输入b后可能得到两种状态,构成一个状态集。

  • 11
    点赞
  • 58
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
厦门理工学院编译原理实验二是指在学习编译原理课程中进行的实验,具体涉及到了NFA(非确定有限自动机)转 DFA(确定有限自动机)的相关内容。 NFADFA都属于有限状态自动机,用于描述形式语言的模型。NFA相对于DFA而言具有更高的表达能力,因为它在某些状态下可以有多个后继状态。而DFA则是在NFA的基础上进行了优化,通过消除不确定性,使得状态转移更加明确和确定。 实验二的主要目的是通过实践操作,加深对NFADFA理解,并且掌握NFADFA的方法。在实验中,我们会先根据给定的正则表达式或自动机图设计一个NFA,然后通过确定状态、转换表和终态等步骤,将NFA转换为DFA。这个转换过程需要考虑NFA中的ε-转移以及多个状态同时转移的情况,从而得到一个等价的DFA。 实验的步骤主要包括:通过给定的正则表达式构建NFA、确定NFA的状态集、计算每个状态的ε-闭包、根据输入符号和ε-闭包进行状态转换,并得到新的状态集和转换表,最后确定DFA的终态。通过这些步骤,我们可以将一个NFA转换为一个等价的DFA,实现了从非确定性到确定性的转变。 在实验过程中,我们需要注意各个状态的转换规则以及ε-闭包的计算和使用,这些是实验中较为重要的部分。通过实际操作和计算,我们可以更好地理解NFADFA之间的关系,并且加深对编译原理中有限状态自动机的理解与应用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值