- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
语法分析实验报告
一:实验内容:
编写语法分析程序,实现对算术表达式的语法分析,要求所分析的算术表达式由如下的文法产生。
E-E+T|E-T|T
T-T*F|T/F|F
F-id|(E)|num
二:实验要求:
在对表达式进行分析的同时,输出所采用的产生式。
1.编写LL(1)语法分析程序,要求:
编程实现算法4.2,为给定的文法自动构造预测分析表
编程实现算法4.1,构造LL(1)预测分析程序,
2.编写语法分析程序,实现自底向上的分析,要求:
构造识别所有活前缀的DFA
构造LR分析表
编程实现算法4.3,构造LR分析程序
三:实验分析:
方法二(编写LL(1)语法分析程序)
1.步骤:
(1)根据题目所给出的文法构造相应的无左递归文法,并求出该文法各非终结符的FIRST、FOLLOW集合;
(2)构造文法的LL(1)分析表;
(3)由此构造LL分析程序。
2.实现方法:
1.输入缓冲区为一个字符型数组,读入输入的算术表达式并保存在此,以’$’结束;
2.为构造文法的LL(1)分析表,构建一个相对应的字符串数组;
3.在实际程序中P代表E,Q代表T,e代表ε,i代表id,n代表num;
4.处理输入表达式中代表id和num的子串,分别将它们转化为i和n进行分析;
5. LL(1)预测分析程序的总控程序在任何时候都是按STACK栈顶符号X和当前的输入符号a做哪种过程的。对于任何(X,a),总控程序每次都执行下述三种可能的动作之一:
(1)若X = a =‘$’,则宣布分析成功,停止分析过程。
(2)若X = a!=‘$’,则把X从STACK栈顶弹出,让a指向下一个输入符号。
①如果是终结符合,则栈不加入新符号
②如果是非终结符合,则把表达式右边入栈
(3)若M[A,a]中存放着“出错标志”,则调用出错诊断程序ERROR。
3.计算过程:
文法对应的无左递归文法为:
E-TE’
E’-+TE’|-TE’|ε
T-FT’
T’-*FT’|/FT’|ε
F-id|(E)|num
求的各个非终结符的FIRST、FOLLOW集合为:
FIRST(E) = { id, num, ( } FOLLOW (E) = { $ , )}
FIRST(E’) = { +, -,ε} FOLLOW (E’) = { $ , )}
FIRST(T) = { id, num, ( } FOLLOW (T) = { $ , + , - , )}
FIRST(T’) = { *,/,ε( } FOLLOW (E’) = { $ , + , - , )}
FIRST(F) ={ id, num, ( } FOLLOW (F) = { $ , + , - , * , / , ) }
方法三(编写语法分析程序,实现自底向上的分析)
1.步骤:
(1)根据题目所给出的文法构造相应的拓广文法,并求出该文法各非终结符的FIRST、FOLLOW集合;
(2)构造拓广文法的项目集规范族,并构造出识别所有前缀的DFA;
(3)构造文法的LR分析表;
(4)由此构造LR分析程序。
2.实现方法:
1.输入缓冲区为一个字符型数组,读入输入的算术表达式并保存在此,以’$’结束;
2.定义两个二维整形数组,goto和action,其值大于零代表移进操作,小于零代表规约操作,引进的状态或规约用到的产生式又绝对值表示。等于零代表出现错误。等于特殊值-10代表acc.状态。
3.在实际程序中P代表E,Q代表T,e代表ε,i代表id,n代表num;
4.处理输入表达式中代表id和num的子串,分别将它们转化为i和n进行分析;
5.根据分析表,相应进行语法分析,移近或规约,按算法4.3的步骤完成过程。
3.计算过程:
文法对应的拓广文法为:
(0)E’-E (1) E - E+T (2)E - E-T (3) E - T (4)T - T*F
(5)T - T/F (6)T - F (7)F - (E) (8)F - id (9)F - num
求的各个非终结符的FIRST、FOLLOW集合为:
FIRST(E’) = { id, num, ( } FOLLOW (E’) = { $ }
FIRST(E) = { id, num, ( } FOLLOW (E) = { $ , + , - , ) }
FIRST(T) = { id, num, ( } FOLLOW (T) = { $ , + , - , * , / , ) }
FIRST(F) ={ id, num, ( } FOLLOW (F) = { $ , + , - , * , / , ) }
4.SLR(1)分析表为:
状态
+
-
*
/
(
)
Id
Num
$
原创力文档


文档评论(0)