java 编译原理 ll1 文法分析 first follow select 集的 求解
2021-05-13 15:59:30 28KB java 编译原理 ll1 文法分析
1
实验二 语法分析—(1)递归下降分析法 程序输入/输出示例: 对下列文法,用递归下降分析法对任意输入的符号串进行分析: (1)E->eBaA (2)A->a|bAcB (3)B->dEd|aC (4)C->e|dC 输出的格式如下: (1)递归下降分析程序,编制人:姓名,学号,班级 (2)输入一以#结束的符号串:在此位置输入符号串例如:eadeaa# (3)输出结果:eadeaa#为合法符号串
2021-05-10 19:27:33 3KB java 编译原理
1
对于文法: E->TG G->+TG|-TG|ε T->FS S->*FS|/FS|ε F->(E)|i 用LL(1)分析法对任意输入的符号串进行分析,输入输出参考main函数。(预测分析表详见tab数组)
2021-05-07 19:43:54 5KB Java 编译原理 LL(1) 词法
1
nput.txt是输入的测试文件。 produce.txt是输入的LR1产生式,能力不大,能if,while,赋值,加,乘,不能处理任何嵌套,没有数组,(这个你可以自己加文法进去进行处理) Grammar.txt是某个博客上的文法,看着很靠谱,但是我没有再做测试的心思了。。。 这个程序没啥bug,但是文法如果有左递归,那肯定是会出现stack overflow的(书上算法就是这么设计的) 另外LR文法不能有二义性,你得在文法里面把算术优先级给解决了。 另外如果加入嵌套,那必然复杂度指数上升,得跑很久。。。。十分钟似乎都不算多。。 运行指南: gui.JtableParse3.java 显示LR1分析表,同时对input里面的文件进行分析。输出词法分析结果到output.txt 输出规约过程,很小一段语句可能就会很长的规约过程。 letex.LexResult.java 显示词法分析结果。输出全部识别出来的单词。 LR1识别实现完全在Parse3包里,自己看名字去读代码。 几乎每一个主要的类我都写了main()方法,可以自己输入一些产生式去试下, 比如书上给的: S' -> S S -> C C C -> c C|d 得到的集合和LR1的结果和书上完全一致 和一些网址上的 S' -> S S -> L = R S -> R L -> * R L -> id R -> L 你可以通过跑ItemTable.java 得到全部的集合和goto集合, 通过跑gotoTable.java 得到goto表 通过跑ActionTable.java 得到action表(cmd形式) 通过跑parse.java 得到两张表的合集和规约过程。 gui.JtableParse3.java 把上面的两张表合在一起图形化了。 我鼓励你发现我的bug *0*虽然我仔细检察过并没有bug 但你可以发布修复bug的最新版本。注意标明原转载网址奥。 更加详细的思路和其他的说明,见下面的网址: https://blog.csdn.net/qinglingLS 和: https://blog.csdn.net/qinglingLS/article/details/89814398 【HIT哈工大编译原理实验】词法分析程序java 【编译原理】求first集合的代码实现java 【编译原理】求GOTO图的代码实现java 【编译原理】LL(1)分析法代码 其他的更新版本可以自己去博客里找一下噢。 写于2019/5/8
2021-05-03 20:09:52 1MB java 编译原理
1
对于文法: E->TG G->+TG|-TG|ε T->FS S->*FS|/FS|ε F->(E)|i 用递归下降分析法对任意输入的符号串进行分析,输入输出参考main函数。
2021-04-30 15:23:10 863B Java 编译原理 递归下降 词法
1
编译原理 词法分析 java 带界面 可用winbuider更改界面
2021-04-19 10:01:52 20.64MB java 编译原理
1
编译原理大作业 含FA图 java词法分析器 C语言编写
2021-04-16 17:38:16 193KB java 编译原理
1
jclasslib编译class文件 重新打包jar
1
windows下的java编译器和jdk.zip
2021-02-27 20:04:04 484.63MB java
1
java编译器与jdk
2021-02-23 09:00:49 355.14MB java编译器与jdk下载
1