资源简介
本程序的所用的存储结构都是string类型的,最主要的存储文法的数据结构为自定义结构,里面包括一个产生式的左部,右部以及select集合,至于非终结符的first和follow集合,则是定义了一个string类型的数组进行存储。
本程序的求first,follow,select集合的算法即为书上所介绍的方法,即求first的集合时,只看本产生式,求follow集合时,要进行递归查找一个非终结符的所有后跟字符,求select其实就是对first与follow集合的运算,最终根据所有的select集合,便可以判断此文法是否为LL(1)文法。
对于不是LL(1)文法的产生式,本程序在判断后进行转换,先进行消除左递归,然后提取左公因子,在这两步的每一步结束之后,都要对产生式进行整合,去掉空存储,去掉无法到达的产生式,将select全部置空。
每进行一次非LL(1)到LL(1)的转换之后,都要对其文法性质进行判断,如果是LL(1),则跳出,不是则继续,但是当循环一定次数之后仍不是,程序判定其无法转换,也要跳出。
其中还有对第一个非终结字符的右部替换与否进行选择,原因是,有些通过替换就可以很方便的进行转换,这个要通过人为进行输入。
提取公因子中也有上一段所说的类似的判断机制,目的是为了防止文法的左公因子无法提取完的情况出现。
最终有三种结果,一种是是LL(1)文法,一种是不是LL(1),但是经过转换变成了LL(1),还有一种是经过转换也无法变成LL(1)。
输入文本格式样例:
A
A->ad
A->Bc
B->aA
B->bB
代码片段和文件信息
相关资源
- Chomsky文法类型判断编译原理实验完整
- 山东大学编译原理2017试题
- 编译原理答案陈文宇、王晓斌
- 编译原理作业-表达式编译器
- 编译原理1题库完整版含答案
- Tiger语言语法手册
- 程序设计语言编译原理第三版课后习
- 编译原理课程设计 南京航空航天大学
- 编译原理算符优先文法实验源码
- 哈工大 编译原理作业
- 编译原理C-编译器源代码_min
- 编译原理.rar
- 南京理工大学编译原理复习题
- 编译原理课程设计:基于表达式的计
- 编译原理实验 求first集和follow集 代码
- 燕山大学软件工程编译原理实验报告
- 自动机向正规文法的转换
- 编译原理第三版课后习题及部分答案
- 程序设计语言与编译 语言的设计和实
- 计算机编译原理 张幸儿 第三版课后习
- 编译原理第三版试题及答案
- FirstVT集和LastVT集生成算法模拟编译原
- 编译原理:正规式判断字符串是否匹
- 四川大学计算机学院 C-语言编译器 编
- 《编译原理及实现》
- 编译原理课后答案蒋立源版
- 编译原理课堂笔记 史上最详细 最牛
- 陈火旺编译原理第三版课后习题答案
- DFA的最小化 完整可运行代码
- 正规文法转正规式+正规式NFA完整可运
评论
共有 条评论