ImageVerifierCode 换一换
格式:DOCX , 页数:22 ,大小:23.47KB ,
资源ID:9345848      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9345848.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(实验三算符优先分析算法的设计与实现.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

实验三算符优先分析算法的设计与实现.docx

1、实验三算符优先分析算法的设计与实现实验三 算符优先分析算法的设计与实现(8学时)一、 实验目的根据算符优先分析法,对表达式进行语法分析,使其能够判断一个表达式是否正确。通过算符优先分析方法的实现,加深对自下而上语法分析方法的理解。二、 实验要求1、输入文法。可以是如下算术表达式的文法(你可以根据需要适当改变): EE+T|E-TTTT*FT/F|FF(E)i2、对给定表达式进行分析,输出表达式正确与否的判断。程序输入/输出示例:输入:1+2;输出:正确输入:(1+2)/3+4-(5+6/7);输出:正确输入:((12)/3+4输出:错误输入:1+2-3+(*4/5)输出:错误三、实验步骤1、参

2、考数据结构char *VN=0,*VT=0;/非终结符和终结符数组char firstvtNN,lastvtNN,tableNN;typedef struct /符号对(P,a) char Vn; char Vt; VN_VT;typedef struct /栈 VN_VT top; VN_VT bollow; int size;stack;2、根据文法求FIRSTVT集和LASTVT集给定一个上下文无关文法,根据算法设计一个程序,求文法中每个非终结符的FirstVT 集和LastVT 集.算符描述如下:/求 FirstVT 集的算法*/ PROCEDURE insert(P,a); IF n

3、ot FP,a then begin FP,a = true; /(P,a)进栈 end; Procedure FirstVT; Begin for 对每个非终结符 P和终结符 a do FP,a = false for 对每个形如 P a或 PQa的产生式 do Insert(P,a) while stack 非空 begin 栈顶项出栈,记为(Q,a) for 对每条形如 PQ的产生式 do insert(P,a) end; end.同理,可构造计算LASTVT的算法。3、构造算符优先分析表依据文法和求出的相应FirstVT和 LastVT 集生成算符优先分析表。算法描述如下:for 每个

4、形如 PX1X2Xn的产生式 do for i =1 to n1 do begin if Xi和Xi+1都是终结符 then Xi = Xi+1 if i= n2, Xi和Xi+2 是终结符, 但Xi+1 为非终结符 then Xi = Xi+2 if Xi为终结符, Xi+1为非终结符 then for FirstVT 中的每个元素 a do Xi a ; if Xi为非终结符, Xi+1为终结符 then for LastVT 中的每个元素 a do a Xi+1 ; end4、构造总控程序 算法描述如下: stack S; k = 1; /符号栈S的使用深度 Sk = REPEAT 把下

5、一个输入符号读进a中; If Sk VT then j = k else j = k-1; While Sj a do Begin Repeat Q = Sj; if Sj1 VT then j = j-1 else j = j2 until Sj Q; 把Sj+1Sk归约为某个N,并输出归约为哪个符号; K = j+1; Sk = N; end of while if Sj a or Sj = a then begin k = k+1; Sk = a end else error /调用出错诊察程序 until a = #5、对给定的表达式,给出准确与否的分析过程6、给出表达式的计算结果。(

6、本步骤可选作)四、实验报告要求1.写出编程思路、源代码(或流程图);2。写出上机调试时发现的问题,以及解决的过程;3。写出你所使用的测试数据及结果;4。谈谈你的体会.5.上机8小时,完成实验报告2小时.五、源代码 #includeiostream。h#includestring.hinclude=A&ch=Z) return 1; else return 0;/judge1是判断是否是算符文法:若产生式中含有两个相继的非终结符则不是算符文法int judge1(int n)int j=3,flag=0;for(int i=0;i=n;i+)while(strij!=0)char a=strij

7、;char b=strij+1;if(IsLetter(a)IsLetter(b))/两个非终结符相连,不是算符文法flag=1;break;else j+;if(flag=1)/根据flag设定返回值return 0;elsereturn 1;/judge2是判断文法G是否为算符优先文法:若不是算符文法或若文法中含空字或终结符的优先级不唯一则不是算符优先文法void judge2(int n)for(int i=0;i=n;i+)if(stri3=|FLAG=1)/代表空cout文法G不是算符优先文法!n)cout”文法G是算符优先文法!”endl;/search1是查看存放终结符的数组r中

8、是否含有重复的终结符int search1(char r,int kk,char a)for(int i=0;ikk;i+)if(ri=a)break;if(i=kk) return 0;else return 1;/createF函数是用F数组存放每个终结符与非终结符和组合,并且值每队的标志位为0;F数组是一个结构体void createF(int n)int k=0,i=1;char g;char t10;/t数组用来存放非终结符t0=str00;while(i=n)if(tk!=stri0)k+;tk=stri0;g=tk;i+;else i+;kk=0;char c;for(i=0;i

9、=n;i+) int j=3;while(strij!=0)c=strij;if(IsLetter(c)=0)if(!search1(r,kk,c))rkk=c;kk+;/r数组用来存放终结符j+;m=0;for(i=0;ik;i+)for(int j=0;jkk1;j+)Fm。R=ti;Fm。r=rj;Fm.flag=0;m+;/search函数是将在F数组中寻找到的终结符与非终结符对的标志位值为1void search(charLode w)for(int i=0;im;i+)if(Fi。R=w。E&Fi。r=w。e)Fi.flag=1;break;void FirstVT(int n)/

10、求FirstVTcharstack sta;charLode w;int i=0;Initstack(sta);while(i=n)int k=3;w。E=stri0;char a=strik;char b=strik+1;if(!IsLetter(a))/产生式的后选式的第一个字符就是终结符的情况w。e=a;push(sta,w);search(w);i+;else if(IsLetter(a)&b!=0&!IsLetter(b))/产生式的后选式的第一个字符是非终结符的情况w.e=b;push(sta,w);search(w);i+;else i+;charLode ww;while(!I

11、sEmpty(sta))pop(sta,ww);for(i=0;i=n;i+)w。E=stri0;if(stri3=ww。E&stri4=0)w.e=ww。e;push(sta,w);search(w);break;p=0;int k=1;i=1;while(im)if(Fi1。flag=1)arrp0=Fi1.R;arrpk=Fi1.r;while(Fi。flag=0&im)i+;if(Fi。flag=1)if(Fi.R=arrp0)k+;else arrpk+1=0;p+;k=1;i+; void LastVT(int n)/求LastVTcharstack sta;charLode w;

12、for(int i=0;im;i+)Fi.flag=0;i=0;Initstack(sta);while(i=n)int k=strlen(stri);w。E=stri0;char a=strik-1;char b=strik-2;if(!IsLetter(a))w.e=a;push(sta,w);search(w);i+;else if(IsLetter(a)&!IsLetter(b))w。e=b;push(sta,w);search(w);i+;else i+;charLode ee;while(!IsEmpty(sta)pop(sta,ee);for(i=0;i=n;i+)w。E=str

13、i0;if(stri3=ee。E&stri4=0)w.e=ee。e;push(sta,w);search(w);int k=1;i=1;ppp=0;while(im)if(Fi-1.flag=1)brrppp0=Fi1.R;brrpppk=Fi1.r;while(Fi.flag=0&im)i+;if(Fi。flag=1)if(Fi。R=arrppp0)k+;else brrpppk+1=0;ppp+;k=1;i+; void createYXB(int n)/构造优先表int i,j;for(j=1;j=kk;j+)ccrr10j=rj-1;for( i=1;i=kk;i+)ccrr2i0=r

14、i1;for(i=1;i=kk;i+)for(j=1;j=kk;j+)crrij=0;int I=0,J=3;while(I=n)if(strIJ+1=0)/扫描右部I+;J=3;elsewhile(strIJ+1!=0)char aa=strIJ;char bb=strIJ+1;if(!IsLetter(aa)&!IsLetter(bb))/优先及等于的情况,用1值表示等于for(i=1;i=kk;i+) if(ccrr2i0=aa)break; for(j=1;j=kk;j+)if(ccrr10j=bb)break;if(crrij=0)crrij=1;else FLAG=1;I=n+1;J+;if(!IsLetter(aa)&IsLetter(bb)&strIJ+2!=0&!IsLetter(strIJ+2)/优先及等于的情况for(i=1;i=kk;i+) if(ccrr2i0=aa)break;for(int j=1;j=kk;j+) if(ccrr10j=strIJ+2)break;if(crrij=0)crrij=1;else FLAG=1;I=n+1;if(!IsLetter(aa)&IsLetter(bb))/优先及小于的情况,用2值表示小于for(i=1;i=k

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1