正则表达式转换成nfa如何实现?
nfa是一种抽象的数据结构,其具体实现是可变的,它依赖于特定的语言……
一种是字节码的表达,可以看作是一种线性化的nfa。代码可以引用regex/regcomp。c在master·garyhouston/regex·github上,逐字扫描正则表达式,直接生成字节码,表示正则表达式的语法与嵌套词相同,因此不需要进行复杂的处理,如ast生成。。。perl和oniguruma都是从这个古老的vm演变而来的
!但是字节码不便于执行诸如“转换为dfa”之类的操作。让我们从定义来看:nfa定义中最重要的是一组状态转换函数。然后你可以改变所有的转换函数(边)所有的建模都是可以的:
为了便于后续计算,你可以按边或输入c,或按from琰state,或按to琰state可以被索引并放入哈希表
原文标题:根据文本生成正则表达式 正则表达式转换成nfa如何实现?,如若转载,请注明出处:https://www.saibowen.com/news/23539.html
免责声明:此资讯系转载自合作媒体或互联网其它网站,「赛伯温」登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,文章内容仅供参考。