编译原理词法分析,语法分析实验报告_第1页
编译原理词法分析,语法分析实验报告_第2页
免费预览已结束,剩余1页可下载查看

下载本文档

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

文档简介

1、 5/5编译原理词法分析,语法分析实验报告 编译原理实验报告 一LL(1)文法分析 1.设计要求 (1)对输入文法,它能判断是否为LL(1)文法,若是,则转(2);否则报错并终止; (2)输入已知文法,由程序自动生成它的LL(1)分析表; (3)对于给定的输入串,应能判断识别该串是否为给定文法的句型。 2.分析 该程序可分为如下几步: (1)读入文法 (2)判断正误 (3)若无误,判断是否为LL(1)文法 (4)若是,构造分析表; (5)由总控算法判断输入符号串是否为该文法的句型。 3.流程图 4.源程序 /* 语法分析程序 :xxx 学号:xxx */ #include #include #

2、include /*/ int count=0; /*分解的产生式的个数*/ int number; /*所有终结符和非终结符的总数*/ char start; /*开始符号*/ char termin50; /*终结符号*/ char non_ter50; /*非终结符号*/ char v50; /*所有符号*/ char left50; /*左部*/ char right5050; /*右部*/ char first5050,follow5050; /*各产生式右部的FIRST和左部的FOLLOW集合*/ char first15050; /*所有单个符号的FIRST集合*/ char s

3、elect5050; /*各单个产生式的SELECT集合*/ char f50,F50; /*记录各符号的FIRST和FOLLOW是否已求过*/ char empty20; /*记录可直接推出的符号*/ char TEMP50; /*求FOLLOW时存放某一符号串的FIRST集合*/ int validity=1; /*表示输入文法是否有效*/ int ll=1; /*表示输入文法是否为LL(1)文法*/ int M2020; /*分析表*/ char choose; /*用户输入时使用*/ char empt20; /*求_emp()时使用*/ char fo20; /*求FOLLOW集合时

4、使用*/ /* 判断一个字符是否在指定字符串中 */ int in(char c,char *p) int i; if(strlen(p)=0) return(0); for(i=0;i+) if(pi=c) return(1); /*若在,返回1*/ if(i=strlen(p) return(0); /*若不在,返回0*/ /* 得到一个不是非终结符的符号 */ char c() char c=A; while(in(c,non_ter)=1) c+; return(c); /* 分解含有左递归的产生式 */ void recur(char *point) /*完整的产生式在point中*

5、/ int j,m=0,n=3,k; char temp20,ch; ch=c(); /*得到一个非终结符*/ k=strlen(non_ter); non_terk=ch; non_terk+1=0; for(j=0;j) printf(ninput error!); validity=0; return(0); /*检测输入错误*/ for(k=0;k=i-1;k+) /*分解输入的各产生式*/ if(pk3=pk0) recur(pk); else non_re(pk); return(s); /* 将单个符号或符号串并入另一符号串 */ void merge(char *d,char

6、*s,int type) /*d是目标符号串,s是源串,type1,源串中的 一并并入目串; type2,源串中的 不并入目串*/ int i,j; for(i=0;i=strlen(s)-1;i+) if(type=2 else for(j=0;j+) if(jstrlen(d) if(j=strlen(d) dj=si; dj+1=0; break; /* 求所有能直接推出的符号 */ void emp(char c) /*即求所有由 推出的符号*/ char temp10; int i; for(i=0;i=count-1;i+) if(righti0=c temp1=0; merge(

7、empty,temp,1); emp(lefti); /* 求某一符号能否推出 */ int _emp(char c) /*若能推出,返回1;否则,返回0*/ int i,j,k,result=1,mark=0; char temp20; temp0=c; temp1=0; merge(empt,temp,1); if(in(c,empty)=1) return(1); for(i=0;i+) if(i=count) return(0); if(lefti=c) /*找一个左部为c的产生式*/ j=strlen(righti); /*j为右部的长度*/ if(j=1 else if(j=1 else for(k=0;k=j-1;k+) if(in(rightik,empt)=1) mark=

温馨提示

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

评论

0/150

提交评论