LL(1)语法分析程序实验报告(共22页).doc





《LL(1)语法分析程序实验报告(共22页).doc》由会员分享,可在线阅读,更多相关《LL(1)语法分析程序实验报告(共22页).doc(22页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上 编译原理上机实验报告1.设计要求 (1)对输入文法,它能判断是否为LL(1)文法,若是,则转(2);否则报错并终止; (2)输入已知文法,由程序自动生成它的LL(1)分析表; (3)对于给定的输入串,应能判断识别该串是否为给定文法的句型。2.分析 该程序可分为如下几步:(1)读入文法 (2)判断正误 (3)若无误,判断是否为LL(1)文法 (4)若是,构造分析表;(5)由总控算法判断输入符号串是否为该文法的句型。开始读入文法有效?是LL(1)文法?判断句型报错结束3.流程图 是是4.源程序/* 语法分析程序 作者: 学号: */#include#include#in
2、clude/*/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 select5050; /*各
3、单个产生式的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;size_t 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中*/ int j,m=0,n=3,k;char temp20,ch;c
5、h=c(); /*得到一个非终结符*/k=strlen(non_ter);non_terk=ch;non_terk+1=0;for(j=0;size_t(j)=strlen(point)-1;j+)if(pointn=point0) /*如果|后的首符号和左部相同*/for(j=n+1;size_t(j)=strlen(point)-1;j+) while(pointj!=|&pointj!=0) tempm+=pointj+;leftcount=ch;memcpy(rightcount,temp,m);rightcountm=ch;rightcountm+1=0;m=0;count+;if(
6、pointj=|)n=j+1;break;else /*如果|后的首符号和左部不同*/leftcount=ch;rightcount0=;rightcount1=0;count+;for(j=n;size_t(j)=strlen(point)-1;j+) if(pointj!=|) tempm+=pointj; else leftcount=point0; memcpy(rightcount,temp,m); rightcountm=ch; rightcountm+1=0;printf( count=%d ,count);m=0; count+; leftcount=point0; memcp
7、y(rightcount,temp,m); rightcountm=ch; rightcountm+1=0;count+; m=0;/* 分解不含有左递归的产生式*/void non_re(char *point) int m=0,j;char temp20;for(j=3;size_t(j)=strlen(point)-1;j+) if(pointj!=|) tempm+=pointj;else leftcount=point0; memcpy(rightcount,temp,m); rightcountm=0;m=0;count+; leftcount=point0; memcpy(rig
8、htcount,temp,m); rightcountm=0; count+;m=0;/* 读入一个文法*/char grammer(char *t,char *n,char *left,char right5050)char vn50,vt50;char s;char p5050;int i,j,k;printf(n请输入文法的非终结符号串:); scanf(%s,vn);getchar(); i=strlen(vn); memcpy(n,vn,i);ni=0;printf(请输入文法的终结符号串:); scanf(%s,vt);getchar(); i=strlen(vt); memcpy
9、(t,vt,i);ti=0; printf(请输入文法的开始符号:);scanf(%c,&s);getchar();printf(请输入文法产生式的条数:); scanf(%d,&i);getchar(); for(j=1;j=i;j+)printf(请输入文法的第%d条(共%d条)产生式:,j,i);scanf(%s,pj-1); getchar(); for(j=0;j)printf(ninput error!); validity=0;return(0); /*检测输入错误*/ for(k=0;k=i-1;k+) /*分解输入的各产生式*/ if(pk3=pk0) recur(pk);e
10、lse non_re(pk);return(s);/* 将单个符号或符号串并入另一符号串*/void merge(char *d,char *s,int type) /*d是目标符号串,s是源串,type1,源串中的 一并并入目串; type2,源串中的 不并入目串*/ int i,j;for(i=0;size_t(i)=strlen(s)-1;i+) if(type=2&si=);elsefor(j=0;j+) if(size_t(j)strlen(d)&si=dj) break; if(size_t(j)=strlen(d) dj=si; dj+1=0; break;/* 求所有能直接推出
11、的符号*/void emp(char c) /*即求所有由 推出的符号*/char temp10;int i;for(i=0;i=count-1;i+)if(righti0=c&strlen(righti)=1)temp0=lefti;temp1=0;merge(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)re
12、turn(1);for(i=0;i+)if(i=count) return(0);if(lefti=c) /*找一个左部为c的产生式*/ j=strlen(righti); /*j为右部的长度*/if(j=1&in(righti0,empty)=1) return(1);else if(j=1&in(righti0,termin)=1)return(0);else for(k=0;k=j-1;k+) if(in(rightik,empt)=1)mark=1;if(mark=1)continue;else for(k=0;k=j-1;k+)result*=_emp(rightik);temp0=
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- LL 语法分析 程序 实验 报告 22

限制150内