- 1、本文档共31页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
课程设计(论文)-语法分析器的实现汇
目录
1.语法分析方法 1
1.1 实验内容 1
1.2 语法分析器的实现 2
1.3 语法分析的程序流程图 2
2.程序设计 3
2.1 总体设计 3
2.2 子程序设计 8
3.程序中的结构说明 10
3.1 重要函数介绍及函数代码 10
4.程序测试 29
4.1 程序测试截图: 29
5 实验总结 31
1.语法分析方法
1.1 实验内容
语法分析程序用LL(1)语法分析方法。首先输入定义好的文法书写文件(所用的文法可以用LL(1)分析),先求出所输入的文法的每个非终结符是否能推出空,再分别计算非终结符号的FIRST集合,每个非终结符号的FOLLOW集合,以及每个规则的SELECT集合,并判断任意一个非终结符号的任意两个规则的SELECT集的交集是不是都为空,如果是,则输入文法符合LL(1)文法,可以进行分析。
题目:
已知文法G[S]:
S→MH|a H→LSo|ε K→dML|ε L→eHf M→K|bLM
判断G 是否是LL(1)文法。
解:文法展开为:
0) S→M H
1) S→a
2) H→L S o
3) H→ε
4) K→d M L
5) K→ε
6) L→e H f
7) M→K
8) M→b L M
非终结符 FIRST 集 FOLLOW 集 S {a,d,b,ε,e} {#,o} M {d,ε,b}. {e,#,o} H {ε,e} . {#,f,o}.... L {e}.... {a,d,b,e,o,#} K {d,ε}.. {e,#,o}... 对相同左部的产生式可知:
SELECT(S→M H)∩SELECT(S→a) ={ d,b ,e,#,o }∩ { a }=空集
SELECT(H→L S o)∩SELECT(H→ε) ={ e }∩ { #,f,o }=空集
SELECT(K→d M L)∩SELECT(K→ε) ={ d }∩ { e,#,o }=空集
SELECT(M→K)∩SELECT(M→b L M) ={ d,e,#,o }∩ { b }=空集
所以文法是LL(1)的。
1.2 语法分析器的实现
语法分析是编译过程的核心部分,它的主要任务是按照程序的语法规则,从由词法分析输出的源程序符号串中识别出各类语法成分,同时进行词法检查,为语义分析和代码生成作准备。这里采用自顶向下的LL(1)分析方法。
该程序可分为如下几步:
(1)读入文法
(2)判断正误
(3)若无误,判断是否为LL(1)文法
(4)若是,构造分析表;
(5)由句型判别算法判断输入符号串是为该文法的句型。
1.3 语法分析的程序流程图
2.程序设计
2.1 总体设计
2.1.1 求能推出空的非终结符集
Ⅰ、实例中求直接推出空的empty集的算法描述如下:
void emp(char c){ 参数c为空符号
char temp[10];定义临时数组
int i;
for(i=0;i=count-1;i++)从文法的第一个产生式开始查找
{
if 产生式右部第一个符号是空符号并且右部长度为1,
then将该条产生式左部符号保存在临时数组temp中
将临时数组中的元素合并到记录可推出符号的数组empty中。
}
Ⅱ、求某一符号能否推出
int _emp(char c)
{ //若能推出,返回1;否则,返回0
int i,j,k,result=1,mark=0;
char temp[20];
temp[0]=c;
temp[1]=\0;
存放到一个临时数组empt里,标识此字符已查找其是否可推出空字
如果c在可直接推出空字的empty[]中,返回1
for(i=0;;i++)
{
if(i==count)
return(0);
找一个左部为c的产生式
j=strlen(right[i]); //j为c所在产生式右部的长度if 右部长度为1且右部第一个字符在empty[]中. then返回1(A-B,B可推出空)
if 右部长度为1但第一个字符为终结符,then 返回0(A-a,a为终结符)
else
{
for(k=0;k=j-1;k++)
{
查找临时数组empt[].并标记mark-=1(A-AB)
if 找到的字符与当前字符相同(A-AB)
结束本次循环
else(mark等于0)
查找右部符号是否可推出空字,把返回值赋给result
把当前符号加入到临时数组empt[]里.
}
if 当前字符不能推
您可能关注的文档
- 课程设计(论文)-卧式车床C6140数控化改造设计汇.doc
- 课程设计(论文)-单片机的红外遥控系统汇.docx
- 课程设计(论文)-单面多轴钻孔组合机床液压系统设计说明书汇.doc
- 课程设计(论文)-利用PWM控制技术实现直流电机的速度控制汇.doc
- 课程设计(论文)-印张计数器设计汇.doc
- 课程设计(论文)-变薄拉深筒设计汇.doc
- 课程设计(论文)-双孔垫片复合模设计汇.doc
- 课程设计(论文)-四层电梯控制系统设计汇.doc
- 课程设计(论文)-图书馆数据库管理系统汇.doc
- 课程设计(论文)-可预置时间的显示播音系统的设计汇.doc
- 2025年北京市农林科学院招聘43人笔试备考题库及完整答案详解1套.docx
- 2025年北京市农林科学院第二批高层次人才引进笔试备考题库及答案详解一套.docx
- 2025年内蒙古鄂尔多斯市行政审批政务服务与数据管理局所属事业单位引进高层次人才笔试备考题库附答案详.docx
- 2025年南充市疾病预防控制中心引进高层次人才考核招聘笔试高频难、易错点备考题库及参考答案详解.docx
- 2025年北京市东城区卫生健康委所属事业单位第一次招聘笔试高频难、易错点备考题库含答案详解.docx
- 2025年北京西城区教委人才引进招聘笔试备考题库含答案详解.docx
- 2025年北京市化工职业病防治院退役大学生士兵定向招聘笔试高频难、易错点备考题库附答案详解.docx
- 2025年嘉兴市检察机关聘用制书记员招录22人笔试备考题库带答案详解.docx
- 2025年南昌市检察机关招聘26名检察辅助人员笔试备考题库及参考答案详解一套.docx
- 2025年北京市农林科学院高层次人才引进34人笔试备考题库带答案详解.docx
文档评论(0)