(1)根据给定文法,先求出FirstVt和LastVt集合,构造算符优先关系表(要求算符优先关系表 输出到屏幕或者输出到文件); (2)根据算法和优先关系表分析给定表达式是否是该文法识别的正确的算术表达式(要求输出归约过程) (3)给定表达式文法为: G(E’): E’→#E# E→E+T | T T→T*F |F F→(E)|i (4)分析的句子为: (i+i)*i和i+i)*i
2019-12-21 19:44:38 2.05MB 算符优先
1
编译原理中LL(1)文法的设计和实现!有说明文档!你懂得!
2019-12-21 19:38:47 80KB LL(1) 编译原理
1
编译原理 算符优先文法 实验报告 代码 运行成功
1
编译原理 算符优先文法 实验报告 代码 运行成功////////////
1
使用MFC实现编译原理LL1语法分析器(含消除左递归)
2019-12-21 19:32:54 2.26MB 编译原理 LL(1) 左递归 mfc
1
东北大学编译原理课设,C语言编译器,C语言文法流程图。 东北大学编译原理课设:C语言编译器,绘制的C语言文法流程图。供学弟学妹们参考,希望对你们有所帮助。
2019-12-21 19:25:32 125KB C语言文法 编译原理 东北大学
1
程序设计语言:主要使用C语言的开发工具,或者采用LEX、YACC等工具,也可利用其他熟悉的开发工具。算法:可以根据《编译原理》课程所讲授的算法进行设计。
1
本程序的所用的存储结构都是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
2019-12-21 19:22:03 214KB 编译原理 LL(1)文法
1
正规文法_NFA_DFA之间的转换实现 有界面
2019-12-21 18:58:11 924KB 正规文法_NFA_DFA之间的转换实现
1
C语言(子集)的BNF文法描述,自己感觉还是挺全的,基本上把C语言中该有部分都包含在内了,,,下了绝对不会后悔的。。。。
2019-12-21 18:56:22 51KB C 语言 子集 BNF
1