ImageVerifierCode 换一换
格式:DOC , 页数:4 ,大小:634KB ,
资源ID:8281870      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-8281870.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(编译原理-编写递归下降语法分析器.doc)为本站会员(精品资料)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

编译原理-编写递归下降语法分析器.doc

1、编译原理上机报告名 称: 编写递归下降语法分析器学 院: 信息与控制工程学院专 业: 计算机科学与技术班 级: 计算机 1401 班姓 名: 叶达成2016 年 10 月 31 日学号 1406410107 成绩一、上机目的通过设计、编制、调试一个递归下降语法分析程序,实现对词法分析程序所提供的单词序列进行语法检查和结构分析,掌握常用的语法分析方法。通过本实验,应达到以下目标:1、掌握从源程序文件中读取有效字符的方法和产生源程序的内部表示文件的方法。2、掌握词法分析的实现方法。3、上机调试编出的词法分析程序。二、基本原理和上机步骤递归下降分析程序实现思想简单易懂。程序结构和语法产生式有直接的对

2、应关系。因为每个过程表示一个非终结符号的处理,添加语义加工工作比较方便。递归下降分析程序的实现思想是:识别程序由一组子程序组成。每个子程序对应于一个非终结符号。每一个子程序的功能是:选择正确的右部,扫描完相应的字。在右部中有非终结符号时,调用该非终结符号对应的子程序来完成。自上向下分析过程中,如果带回溯,则分析过程是穷举所有可能的推导,看是否能推导出待检查的符号串。分析速度慢。而无回溯的自上向下分析技术,当选择某非终结符的产生时,可根据输入串的当前符号以及各产生式右部首符号而进行,效率高,且不易出错。无回溯的自上向下分析技术可用的先决条件是:无左递归和无回溯。无左递归:既没有直接左递归,也没有

3、间接左递归。无回溯:对于任一非终结符号 U 的产生式右部 x1|x2|xn,其对应的字的首终结符号两两不相交。如果一个文法不含回路(形如 P+ P 的推导) ,也不含以 为右部的产生式,那么可以通过执行消除文法左递归的算法消除文法的一切左递归(改写后的文法可能含有以 为右部的产生式) 。三、上机结果测试数据:(1)输入一以#结束的符号串(包括 +*/()i#):在此位置输入符号串例如: i+i*i#(2)输出结果:i+i*i#为合法符号串(3)输入一符号串如 i+i*#,要求输出为“非法的符号串” 。程序清单:#include #include char str50; int index=0;

4、 void E(); /E-TX; void X(); /X-+TX | e void T(); /T-FY void Y(); /Y-*FY | e void F(); /F-(E) | i int main() /*递归分析*/ int len; int m; printf(“请输入要测试的次数:“); scanf(“%d“, while(m-) printf(“请输入字符串(长度):n“); scanf(“%s“,str);len=strlen(str);/strlen=#;strlen+1=0; E(); printf(“%s 为合法符号串!n“,str); strcpy(str,“)

5、; index=0; return 0; void E() T(); X();void X() if(strindex=+) index+; T(); X(); void T() F(); Y(); void Y() if(strindex=*) index+; F(); Y(); void F() if(strindex=i) index+; else if (strindex=() index+; E(); if(strindex=) index+; else printf(“n 非法的符号串 !n“);exit (0); elseprintf(“非法的符号串!n“); exit(0); 屏幕截图:四、讨论与分析通过本次实验对递归下降词法分析器的结构,过程有了更进一步的了解,通过学习书本和试验原理书上的内容,对它的工作原理,具体实行步骤有了进一步的掌握,由于本次试验是测试性试验,所以要求输出的结果是成功与否,输入一个句型,进过分析,判断它是否合法,主要内容在于其判断过程中。本次试验不光提高了自己的编程能力,同时提高了对递归下降的了解。

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报