- 7
- 0
- 约1.65万字
- 约 31页
- 2016-12-04 发布于贵州
- 举报
课程设计(论文)_语法分析器的实现
目录
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 当前字符
您可能关注的文档
- 课程设计(论文)_基于Web的选课系统设计报告.doc
- 课程设计(论文)_基于XML电子病历数字签名算法的研究与实现.doc
- 课程设计(论文)_基于分布式算法的FIR滤波器设计.doc
- 课程设计(论文)_基于切比雪夫I型的高通滤波器设计MATLAB.doc
- 课程设计(论文)_基于单片机出租车计价器.doc
- 课程设计(论文)_基于单片机和DS18B20的数字温度计.doc
- 课程设计(论文)_基于单片机及PC机的电子琴设计.doc
- 课程设计(论文)_基于单片机双通道的多波形发生器.doc
- 课程设计(论文)_基于单片机和温度传感器DS18B20、HS1101是电容式空气湿度传感器.doc
- 课程设计(论文)_基于单片机扩展的LED点阵显示.doc
- 伟明环保-市场前景及投资研究报告-境内业务稳健运行,印尼市场贡献边际增量.pdf
- 桂东县法院系统招聘考试真题2025.pdf
- 贵州省黔南布依族2026年中考三模物理试题及答案.pdf
- 贵州省黔南州2026年中考语文二模试卷附答案.pdf
- 贵州省铜仁市2026年中考语文二模试卷附答案.pdf
- 2026上半年安徽事业单位联考合肥市庐江县招聘36人备考题库及一套完整答案详解.docx
- 贵州省毕节市2026年中考语文一模试卷附答案.pdf
- 贵州省贵阳市南明区2026年中考语文一模试卷附答案.pdf
- 2026上半年安徽事业单位联考合肥市庐江县招聘36人备考题库及一套参考答案详解.docx
- 贵州省贵阳市白云区2026年中考二模物理试题附答案.pdf
最近下载
- 面向产业的算法治理研究(2025年).pptx
- 梵音入汉:佛经汉译对汉语演进的多维影响.docx
- 小学低段音乐课堂管理方法的研究课题资料(包含申请表、开题报告、实施方案、结题报告等).pdf VIP
- 2026《隧道贯通误差预计计算案例》4000字.docx
- 2022-2023学年北京市丰台区高二(下)期末数学试卷(附答案详解).docx VIP
- 5m盐酸溶液的配制 -回复.pdf VIP
- 2026年新疆工程学院辅导员招聘备考题库最新.docx VIP
- 2026年新疆财经大学辅导员招聘备考题库必考题.docx VIP
- 2026年新疆农业大学辅导员招聘备考题库附答案.docx VIP
- 现代金属凝固技术课件(9056KB).ppt VIP
原创力文档

文档评论(0)