# 编译原理课程设计 **Repository Path**: epiphanyers/Regular-Expression-based-NFA-Optimizer-in-Compilation-Curriculum ## Basic Information - **Project Name**: 编译原理课程设计 - **Description**: Regular-Expression-based NFA Optimizer in Compilation Curriculum编译原理课程设计 - **Primary Language**: Unknown - **License**: MulanPSL-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2024-12-01 - **Last Updated**: 2025-01-08 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 梁昊-2022编译原理课程设计 ##### 文档编写:梁昊 1/2025 #### 介绍 Regular-Expression-based DFA Optimizer in Compilation Curriculum编译原理课程设计 #### 软件架构 软件架构说明 本项目实现了一个基于正则表达式到最小化确定性有限自动机(DFA)转换的可视化优化程序,名为`RegEx-DFA Optimizer`。用户通过输入正则表达式,程序通过形式语言与自动机理论中的算法处理,实现正则表达式到非确定性有限自动机(NFA)转换、NFA到确定性有限自动机(DFA)转换,以及DFA的最小化等步骤。转换过程中的中间结果以表格形式展示,最终生成的DFA及其最小化版本则通过状态转换图进行可视化呈现。该程序的设计充分借鉴了词法分析器中的单词形式化描述工具,结合形式语言与自动机的理论基础,支持高效的算法实现和清晰的结果展示。 #### 使用说明 1. QT环境14.0.2 2. 输入正则式 3. 输出结果 #### 标准示例 > (a|b)*(c|d)+ #### 输出DFA状态转换图 ![输入图片说明](imgtest_DFA.png) #### 输出SDFA状态转换图 ![输入图片说明](imgtest_SDFA.png) #### 特技 1. 使用 Readme\_XXX.md 来支持不同的语言,例如 Readme\_en.md, Readme\_zh.md 2. Gitee 官方博客 [blog.gitee.com](https://blog.gitee.com) 3. 你可以 [https://gitee.com/explore](https://gitee.com/explore) 这个地址来了解 Gitee 上的优秀开源项目 4. [GVP](https://gitee.com/gvp) 全称是 Gitee 最有价值开源项目,是综合评定出的优秀开源项目 5. Gitee 官方提供的使用手册 [https://gitee.com/help](https://gitee.com/help) 6. Gitee 封面人物是一档用来展示 Gitee 会员风采的栏目 [https://gitee.com/gitee-stars/](https://gitee.com/gitee-stars/)