c语言5l,实验5LL1语法分析程序的设计与实现C语言.doc

实验五 LL(1)文法识别程序设计

一、实验目的

通过LL(1)文法识别程序的设计理解自顶向下的语法分析思想。

二、实验重难点

FIRST集合、FOLLOW集合、SELECT集合元素的求解,预测分析表的构造。

三、实验内容与要求

实验内容:

阅读并理解实验案例中LL(1)文法判别的程序实现;

参考实验案例,完成简单的LL(1)文法判别程序设计。

四、实验学时

4课时

五、实验设备与环境

C语言编译环境

六、实验案例

实验要求

参考教材93页预测分析方法,94页 图5.11 预测分析程序框图,编写表达式文法的识别程序。要求对输入的LL(1)文法字符串,程序能自动判断所给字符串是否为所给文法的句子,并能给出分析过程。

表达式文法为:

E SKIPIF 1 < 0 E+T|T

T SKIPIF 1 < 0 T*F|F

F SKIPIF 1 < 0 i|(E)

参考代码

为了更好的理解代码,建议将图5.11做如下标注:

/* 程序名称: LL(1)语法分析程序 */

/* E->E+T|T */

/* T->T*F|F */

/* F->(E)|i */

/*目 的: 对输入LL(1)文法字符串,本程序能自动判断所给字符串是否为所给文法的句子,并能给出分析过程。

/********************************************/

/* 程序相关说明 */

/* A=E' B=T' */

/* 预测分析表中列号、行号 */

/* 0=E 1=E' 2=T 3=T' 4=F */

/* 0=i 1=+ 2=* 3=( 4=) 5=# */

/************************************/

#include"iostream"

#include "stdio.h"

#include "malloc.h"

#include "conio.h"

/*定义链表这种数据类型参见:

*/

struct Lchar{

char char_ch;

struct Lchar *next;

}Lchar,*p,*h,*temp,*top,*base;

/*p指向终结符线性链表的头结点,h指向动态建成的终结符线性链表节点,top和base分别指向非终结符堆栈的顶和底*/

char curchar; //存放当前待比较的字符:终结符

char curtocmp; //存放当前栈顶的字符:非终结符

int right;

int table[5][6]={{1,0,0,1,0,0},

{0,1,0,0,1,1},

{1,0,0,1,0,0},

{0,1,1,0,1,1},

{1,0,0,1,0,0}};/*存放预测分析表,1表示有产生式,0表示无产生式。*/

int i,j;

void push(char pchar) /*入栈函数*/

{

temp=(struct Lchar*)malloc(sizeof(Lchar));

temp->char_ch=pchar;

temp->next=top;

top=temp;

}

void pop(void) /*出栈函数*/

{

curtocmp=top->char_ch;

if(top->char_ch!='#')

top=top->next;

}

void doforpush(int t) /*根据数组下标计算的值找对应的产生式,并入栈*/

{

switch(t)

{

case 0:push('A');push('T');break;

case 3:push('A');push('T');break;

case 11:push('A');push('T');push('+');break;

case 20:push('B');push('F');break;

case 23:push('B');push('F');break;

case 32:push('B');push('F');push('*');break;

case 40:push('i');break;

case 43:push(')');push('E');push('(');

}

}

/*根据curchar和curtocmp转为数字以判断是否有产生式*/

void changchartoint()

{

switch(curtocmp) /*非终结符:栈顶*/

{

case 'E':i=0;break;

case 'A':i=1;break;

case 'T':i=2;break;

case 'B':i=3;break;

case 'F':i=4;

}

switch(curchar) /*终结符:待识别的表达式中*/

{

case

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LL1语法分析程序设计是一种基于LL1文法语法分析器设计方法,它可以用来分析和识别输入的语法结构,并生成相应的语法树或者语法分析。在设计LL1语法分析程序时,首先需要确定所使用的文法的类型,并对文法进行分析和修改,以保证它符合LL1的要求。接着需要设计实现相应的文法分析算法,包括LL1分析的构建、分析栈的操作等。 在C语言设计LL1分析程序时,需要先通过词法分析器将输入的源代码转换成词法单元序列,然后将这些词法单元序列作为输入,借助LL1语法分析程序进行语法分析。通过这个过程,可以识别源程序中的语法错误,并将其报告给用户。在实际设计LL1语法分析程序时,通常会利用递归下降分析法或者预测分析法,这些方法都是基于LL1文法的。 在C语言中,LL1语法分析程序设计需要考虑语法的复杂性和灵活性,对于一些复杂的语法结构,可能需要进行一定的优化和调整。此外,还需要考虑如何处理语法冲突和歧义,以便保证程序的准确性和健壮性。在整个程序设计的过程中,需要充分考虑到C语言本身的特点和需求,力求设计出高效、稳定的LL1语法分析程序。 总之,设计C语言LL1语法分析程序需要在理论和实践上做出充分的思考和努力,以确保它能够准确、高效地解析C语言的语法结构。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值