实验二语法分析程序设计与实现_第1页
实验二语法分析程序设计与实现_第2页
实验二语法分析程序设计与实现_第3页
实验二语法分析程序设计与实现_第4页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、;.实验二语法分析程序设计与实现一、实验目的任选一种有代表性的语法分析方法,如算符优先法、递归下降法、 LL(1)、SLR(1)、LR(1)等,通过设计、编制、调试实现一个典型的语法分析程序,对实验一所得扫描器提供的单词序列进行语法检查和结构分析, 实现并进一步掌握常用的语法分析方法。二、基本实验内容与要求选择对各种常见高级程序设计语言都较为通用的语法结构算术表达式的一个简化子集作为分析对象,根据如下描述其语法结构的 BNF 定义 G2< 算术表达式 >,任选一种学过的语法分析方法,针对运算对象为无符号常数和变量的四则运算,设计并实现一个语法分析程序。G2<算术表达式 >

2、;:<算术表达式 > <项 > | < 算术表达式 >+<项 > | < 算术表达式 >-<项 > <项> <因式> | < 项>*<因式> | <项>/<因式><因式 > <运算对象 > | (<算术表达式 >)若将语法范畴 <算术表达式 >、<项 >、<因式 >和<运算对象 >分别用 E、T、F 和 i 代表,则 G2 可写成:G2E: E T | E+T | E-

3、TT F | T*F | T/FF i | (E)输入:由实验一输出的单词串,例如:UCON, PL,UCON, MU,ID·输出:若输入源程序中的符号串是给定文法的句子,则输出“RIGHT”,并且给出每一步分析过程;若不是句子,即输入串有错误,则输出“ERROR”,并且显示分析至此所得的中间结果, 如分析栈、 符号栈中的信息等, 以及必要的出错说明信息。要求 :1、确定语法分析程序的流程图,同时考虑相应的数据结构,编写一个语法分析源程序。2、将词法、语法分析合在一起构成一个完整的程序,并调试成功。3、 供测试的例子应包括符合语法规则的语句, 及分析程序能判别的若干错例。对于所输入的

4、字符串,不论对错,都应有明确的信息输出。三、问题分析及源程序LL1文法 :改写文法为 :E->TGeG>+TGgT->FStF->-TGg1G->g2S->*FSsT->/FSs1S->s2F->(E)f;.'.G->if1分析表:i+-*/()#EeeGgg1g2g2TttSs2s2ss1s2s2Ff1fLL1源程序#include<iostream.h>#include<stdio.h>#include<stdlib.h>#include<string.h>char A30;

5、/* 分析栈 */char B30;/* 剩余串*/char v120='i','+','-','*','/','(',')','#'/* 终结符 */char v220='E','G','T','S','F'/* 非终结符 */int j=0,b=0,top=0,l;/*L 为输入串长度 */class type/* 产生式类型定义 */public:char origin;/* 大写字

6、符 */char array5;/* 产生式右边字符 */int length;/* 字符个数 */;type e,t,g,g1,g2,s,s1,s2,f,f1;/* 类对象*/type C1010;/* 预测分析表 */void print()/* 输出分析栈 */int a;for(a=0;a<=top+1;a+)cout<<Aa;cout<<"tt"void print1()/* 输出剩余串 */int j;for(j=0;j<b;j+) /* 输出对齐符 */ cout<<" "for(j=b;j&

7、lt;=l;j+)cout<<Bj;cout<<"ttt".'.void main()int m,n,k=0,flag=0,finish=0;char ch,x;type cha;/* 用来接受 Cmn*/* 把文法产生式赋值结构体 */e.origin='E'strcpy(e.array,"TG");e.length=2;t.origin='T'strcpy(t.array,"FS");t.length=2;g.origin='G'strcpy(g.ar

8、ray,"+TG");g.length=3;g1.origin='G'strcpy(g1.array,"-TG");g1.length=3;g2.origin='G'g2.array0=''g2.length=1;s.origin='S'strcpy(s.array,"*FS");s.length=3;s1.origin='S'strcpy(s1.array,"/FS");s1.length=3;s2.origin='S'

9、;s2.array0=''s2.length=1;f.origin='F'strcpy(f.array,"(E)");f.length=3;f1.origin='F'f1.array0='i'f1.length=1;for(m=0;m<=4;m+)/* 初始化分析表 */for(n=0;n<=7;n+)Cmn.origin='N'/* 全部赋为空 */* 填充分析表 */C00=e;C05=e;C11=g;C12=g1;C16=g2;C17=g2;C20=t;C25=t;.'

10、.C31=s2;C32=s2;C33=s;C34=s1;C36=s2;C37=s2; C40=f1;C45=f;cout<<"提示 :本程序只能对由 'i','+','-','*','/','(',')' 构成的以 '#'结束的字符串进行分析,n"cout<<"请输入要分析的字符串 :"do/* 读入分析串 */cin>>ch;if(ch!='i')&&(ch!

11、='+')&&(ch!='-')&&(ch!='*')&&(ch!='/')&&(ch!='(')&&(ch!=')')&&(ch!='#')cout<<"输入串中有非法字符 n"exit(1);/ 强制退出程序Bj=ch;j+;while(ch!='#');l=j;/* 分析串长度 */ch=B0;/*当前分析字符 */Atop='

12、#' A+top='E'/*'#','E'进栈*/cout<<"步骤 tt 分析栈 tt 剩余字符 tt 所用产生式 n" dox=Atop-;/*x 为当前栈顶字符 */cout<<k+;cout<<"tt"for(j=0;j<=7;j+)/*判断是否为终结符 */if(x=v1j)flag=1;break;if(flag=1)/*如果是终结符 */if(x='#')finish=1;/*结束标记 */cout<<"a

13、cc!"<<endl;/*接受 */getchar();exit(1);/ 退出程序/*if*/if(x=ch)print();.'.print1();cout<<"匹配"<<endl;ch=B+b;/*下一个输入字符 */flag=0;/*恢复标记 */else/* 出错处理 */print();print1();cout<<"出错"<<endl;/* 输出出错终结符 */exit(1);else/*非终结符处理 */for(j=0;j<=4;j+)if(x=v2j)m=j;/* 行号*/break;for(j=0;j<=7;j+)if(ch=v1j)n=j;/* 列号*/break;cha=Cmn;if(cha.origin!='N')/*判断是否为空 */print();print1();cout<<cha.origin<<"->" /* 输出产生式 */ for(j=0;j<cha.length;j+)cout<<cha.arrayj;cout<<"n"for(j=(cha.leng

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论