当前位置: 首页 > news >正文

理解计算篇--正则表达式转NFA--理论部分

  • 空正则表达式转NFA
  • 单字符正则表达式转NFA
  • 拼接正则表达式转NFA
  • 选择正则表达式转NFA
  • 重复正则表达式转NFA

正则表达式转NFA–实战部分

空正则表达式转NFA

转换步骤:

  • 构建1个只有1个状态的NFA
  • 起始状态也是接受状态
  • 没有规则,即规则集为空

Empty

单字符正则表达式转NFA

转换步骤:

  • 构建1个有2个状态的NFA
  • 第一个状态为起始状态,第二个状态为接受状态
  • 规则集只有1条规则,当 NFA 处于起始状态,且当前读到的字符等于该正则表达式中的字符时,它会转换到接受状态。

Literal

拼接正则表达式转NFA

转换步骤:构建一个新的 NFA

  • 新NFA的起始状态为第一个NFA的起始状态
  • 新NFA的接受状态集为第二个NFA的接受状态集相同
  • 新NFA的规则集包含第一个NFA的所有规则以及第二个NFA的所有规则的并集
  • 添加自由移动规则,将第一个 NFA 的每一个旧接受状态连接到第二个 NFA 的旧起始状态

请注意:

  • 隐含的改变: 在连接后,第一个 NFA 原来的接受状态在新构建的 NFA 中不再是最终的接受状态
  • 无新增状态
  • 有新增规则

Concatenate

选择正则表达式转NFA

转换步骤:构建一个新的NFA

  • 新 NFA 的起始状态为一个新建的起始状态
  • 新 NFA 的接受状态包含两个NFA的接受状态的并集
  • 新 NFA 的规则包含两个NFA的规则的并集
  • 新增两条额外的自由移动规则:将新的起始状态连接到两个NFA的旧起始状态

请注意:

  • 有新增状态,有新增规则

Choose

重复正则表达式转NFA

转换步骤:构建一个新的NFA

  • 新NFA的起始状态为一个新建的状态,同时也是一个接受状态。
  • 新NFA的接受状态包含旧NFA的接受状态
  • 新NFA的规则包含旧NFA的规则
  • 添加一些额外的自由移动规则,将每个旧NFA的接受状态连接到它的旧起始状态
  • 添加一条自由移动规则,将新的起始状态连接到旧起始状态

请注意:

  • 有新增状态,有新增规则

Repeat

示例

(a|b)*a(a|b)


http://www.mrgr.cn/news/98738.html

相关文章:

  • 【Java学习笔记】数据类型转换
  • Linux-ftp tftp vsftpd区别
  • 11-算法打卡-链表-删除链表的倒数第N个节点-leetcode(19)-第十一天
  • Redis高频面试题(含答案)
  • uniapp-商城-27-vuex 通用方法
  • MGR实现mysql高可用性
  • 4G/5G模组----概念+驱动+调试
  • 【八股】计算机网络
  • 日语学习-日语知识点小记-构建基础-JLPT-N4阶段(5):できます 完成了等 しか。。。ない 只有
  • 什么是进程?
  • 【回眸】Tessy集成测试软件使用指南(一)新手使用篇
  • 【开源项目】Excel手撕AI算法深入理解(三):时序(RNN、mamba)
  • 使用cursor进行原型图设计
  • 概念实践极速入门 - 常用的设计模式 - 简单生活例子
  • Flutter:图片在弹窗外部的UI布局
  • 一文掌握RK3568开发板Android13挂载Windows共享目录
  • vue3获取defineOptions的值;vue3获取组件实例;vue3页面获取defineOptions的name
  • 分布式热点网络
  • AI大模型学习九:‌Sealos cloud+k8s云操作系统私有化一键安装脚本部署完美教程
  • 集群搭建Weblogic服务器!