欢迎来到天天文库
浏览记录
ID:61971142
大小:1.17 MB
页数:9页
时间:2021-04-07
《实验的四非递归预测解析告.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、实用文案《编译原理实验》—LR分析器院、系(部)计算机科学与技术学院专业及班级计算机科学与技术专业1403班学号1408030322姓名朱浩日期2017年5月29日标准文档实用文案一、实验目的与任务设计一个非递归预测分析器,实现对表达式语言的分析,理解自上而下语法分析方法的基本思想,掌握设计非递归预测分析器的基本方法。二、实验要求建立文法及其LL(1)分析表表示的数据结构,设计并实现相应的预测分析器,对源程序经词法分析后生成的二元式代码流进行预测分析,如果输入串是文法定义的句子则输出“是”,否则输出
2、“否”。三、文法描述及其LL(1)分析表表达式语言(XL)的语法规则如下:1.程序→表达式;2.
3、表达式;程序3.表达式→表达式+项4.
4、项5.项→项*因式6.
5、因式7.因式→num_or_id8.
6、(表达式)将该语言的文法转换为如下的LL(1)文法:1prgm→expr;prgm’8term→factorterm’2prgm’→prgm9term’→*factorterm’3prgm’→ε10term’→ε4expr→termexpr’11factor→(expr)5expr→ε12factor→
7、num6expr’→+termexpr’13system_goal→prgm7expr’→ε该LL(1)文法的LL(1)分析表如下:TNNum+*();#prgm111prgm’2223expr4455expr’677term88term’1091010factor1211system_goal131313标准文档实用文案对文法中每个文法符号指定一个常数值,符号编码表如下:文法符号常数值备注(Num+);*#4625130终结符(#为输入结束标志)Exprexpr’termterm’factorpr
8、gmprgm’system_goal258260259262261256257263非终结符四、文法及其LL(1)分析表的数据结构文法的产生式可用数组Yy_pushtab[]存放。数组的第一个下标是产生式号,第一个产生式的序号为0;每列按逆序存放该产生式右部各符号的常数值,并以0结束。对于该表达式语言XL的LL(1)分析表,可用数组Yy_d[]存放。第一个下标是非终结符数值,第二个下标是终结符数值,数组元素的值为:0(表示接受),1(表示产生式号),-1(表示语法错)。数组Yy_d[]的具体内容及表
9、示如下:0123456#;+*()Num-10-1-10-1021-1-11-11-14-1-1343-1-1-1-17-17-165-1-16-1-1-1-1-110-111-1998-19-1-112-1-112-112prgm256prgm’257expr258term259expr’260factor261term’262标准文档实用文案system_goal263数组Yy_pushtab[]的具体内容及表示如下:五、预测分析器总控程序结构预测分析器总控程序使用上面的两个表Yy_pushta
10、b、Yy_d和一个分析栈(元素类型为int),其结构如下:初始化;/*把开始符号的常数值压入分析站,输入指向第一个输入符号*/while(分析栈非空){if(栈顶常数表示一个终结符)if(该常数与输入符号的常数不等)报语法错;else{把一个数从栈顶弹出;advance读下一输入符号;}else{/*栈顶的常数表示一个非终结符*/标准文档实用文案what_to_do=Yy_d[栈顶常数][当前输入符号的常数];if(what_to_do==-1)报语法错;else{把栈顶元素弹出栈;把Yy_push
11、tab[what_to_do]中列出的全部常数压入分析栈;}}}请实现该程序。在程序中添加输出栈内容的功能,以便和手工模拟分析过程作比较。六、预测分析控制程序的测试用例用预测分析器和手工模拟两种方式对文法的句子1+2;进行分析。综合分析过程可用下表表示。栈(符号)栈(数值)输入串What_to_dosystem_goalprgmprgm’;exprprgm’;expr’termprgm’;expr’term’factorprgm’;expr’term’Numprgm’;expr’term’prgm’
12、;expr’ prgm’;expr’term +prgm’;expr’termprgm’;expr’term’factorprgm’;expr’term’Numprgm’;expr’term’ prgm’;expr’ prgm’;prgm’ 2632562571258257126025925712602622612571260262625712602622571260257126025922571260259257126026226125712602626257126
此文档下载收益归作者所有