欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    编译原理词法分析语法分析实验报告.docx

    • 资源ID:890827       资源大小:124.37KB        全文页数:55页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    编译原理词法分析语法分析实验报告.docx

    1、编译原理词法分析语法分析实验报告编译原理实验报告一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#include/*/in

    2、t 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; /*各单个产生式的SELE

    3、CT集合*/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集合时使用*/* 判断一个字符是否在指定字符串中*/int in(cha

    4、r 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中*/ int j,m=0,n=3,k; char temp20,ch; ch=c();

    5、 /*得到一个非终结符*/ k=strlen(non_ter); non_terk=ch; non_terk+1=0; for(j=0;j=strlen(point)-1;j+) if(pointn=point0) /*如果|后的首符号和左部相同*/ for(j=n+1;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(pointj=|)

    6、 n=j+1; break; else /*如果|后的首符号和左部不同*/ leftcount=ch; rightcount0=; rightcount1=0; count+; for(j=n;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; memcpy(right

    7、count,temp,m); rightcountm=ch; rightcountm+1=0; count+; m=0; /* 分解不含有左递归的产生式*/void non_re(char *point) int m=0,j; char temp20; for(j=3;j=strlen(point)-1;j+) if(pointj!=|) tempm+=pointj; else leftcount=point0; memcpy(rightcount,temp,m); rightcountm=0; m=0; count+; leftcount=point0; memcpy(rightcount,

    8、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); memc

    9、py(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)

    10、recur(pk); else non_re(pk); return(s);/* 将单个符号或符号串并入另一符号串*/void merge(char *d,char *s,int type) /*d是目标符号串,s是源串,type1,源串中的 一并并入目串; type2,源串中的 不并入目串*/ int i,j; for(i=0;i=strlen(s)-1;i+) if(type=2&si=) ; else for(j=0;j+) if(jstrlen(d)&si=dj) break; if(j=strlen(d) dj=si; dj+1=0; break; /* 求所有能直接推出的符号*/v

    11、oid 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,em

    12、pty)=1) return(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

    13、*=_emp(rightik); temp0=rightik; temp1=0; merge(empt,temp,1); if(result=0&icount) continue; else if(result=1&icount) return(1); /* 判断读入的文法是否正确*/int judge() int i,j; for(i=0;i=count-1;i+) if(in(lefti,non_ter)=0) /*若左部不在非终结符中,报错*/ printf(nerror1!); validity=0; return(0); for(j=0;j=strlen(righti)-1;j+)

    14、if(in(rightij,non_ter)=0&in(rightij,termin)=0&rightij!=) /*若右部某一符号不在非终结符、终结符中且不为 ,报错*/ printf(nerror2!); validity=0; return(0); return(1);/* 求单个符号的FIRST*/void first2(int i) /*i为符号在所有输入符号中的序号*/ char c,temp20; int j,k,m; c=vi; char ch=; emp(ch); if(in(c,termin)=1) /*若为终结符*/ first1i0=c; first1i1=0; els

    15、e if(in(c,non_ter)=1) /*若为非终结符*/ for(j=0;j=count-1;j+) if(leftj=c) if(in(rightj0,termin)=1|rightj0=) temp0=rightj0; temp1=0; merge(first1i,temp,1); else if(in(rightj0,non_ter)=1) if(rightj0=c) continue; for(k=0;k+) if(vk=rightj0) break; if(fk=0) first2(k); fk=1; merge(first1i,first1k,2); for(k=0;k=s

    16、trlen(rightj)-1;k+) empt0=0; if(_emp(rightjk)=1&k=0) firsti0=; firsti1=0; else TEMP0=; TEMP1=0; else for(j=0;j+) if(vj=p0) break; if(i=0) memcpy(firsti,first1j,strlen(first1j); firstistrlen(first1j)=0; else memcpy(TEMP,first1j,strlen(first1j); TEMPstrlen(first1j)=0; else /*如果右部为符号串*/ for(j=0;j+) if(

    17、vj=p0) break; if(i=0) merge(firsti,first1j,2); else merge(TEMP,first1j,2); for(k=0;k=length-1;k+) empt0=0; if(_emp(pk)=1&k=0) merge(firsti,first1m,2); else merge(TEMP,first1m,2); else if(_emp(pk)=1&k=length-1) temp0=; temp1=0; if(i=0) merge(firsti,temp,1); else merge(TEMP,temp,1); else if(_emp(pk)=0

    18、) break; /* 求各产生式左部的FOLLOW*/void FOLLOW(int i) int j,k,m,n,result=1; char c,temp20; c=non_teri; /*c为待求的非终结符*/ temp0=c; temp1=0; merge(fo,temp,1); if(c=start) /*若为开始符号*/ temp0=#; temp1=0; merge(followi,temp,1); for(j=0;j=count-1;j+) if(in(c,rightj)=1) /*找一个右部含有c的产生式*/ for(k=0;k+) if(rightjk=c) break; /*k为c在该产生式右部的序号*/ for(m=0;m+) if(vm=leftj) break; /*m为产生式左部非终结符在所有符号中的序号*/ if(k=strlen(rightj)-1) /*如果c在产生式右部的最后*/ if(in(vm,fo)=1) merge(followi,followm,1); continue; if(Fm=0) FOLLOW(m); Fm=1; merge(followi,followm,1); els


    注意事项

    本文(编译原理词法分析语法分析实验报告.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开