编译原理语法分析实验二-表达式语法分析器的设计实现.doc_第1页
编译原理语法分析实验二-表达式语法分析器的设计实现.doc_第2页
编译原理语法分析实验二-表达式语法分析器的设计实现.doc_第3页
编译原理语法分析实验二-表达式语法分析器的设计实现.doc_第4页
编译原理语法分析实验二-表达式语法分析器的设计实现.doc_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

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

文档简介

编译原理程序设计实验报告实验题目班级:计算机1306姓名:学号:实验目标:表达式语法分析器的设计实现1) 递归下降子程序2) LL(1)分析法 实验内容:1. 概要设计1) 按照流程图,调用子程序实现;2) 通过ll(1)分析表和对应压栈、弹栈操作实现。2. 流程图1) 递归:Z(main):开始Read(w)E#? N Err结束入口入口E: E1:+?T YE1Read(w)-? N出口 Y T N出口入口入口T: T1:*?F YRead(w)/?T1 N出口 YT N入口出口F:(?I? N N errRead(w) Y YRead(w)E)? 出口 Y N err2) LL(1):调用函数token()切分单词构建LL(1)分析表开始调用*Analyse(char *token)进行分析结束3. 关键函数1) 递归下降子程序void E();/E-TX;int E1();/X-+TX | evoid T();/T-FYint T1();/Y-*FY | eint F();/F-(E) | i2) LL(1)分析法 char *Find(char vn,char vt)/是否查到表char *Analyse(char *token)/分析过程int Token()/将token中数字表示成i,标识符表示成n源程序代码:(加入注释)1) 递归下降子程序:#include#include#include #include using namespace std;/*全局变量*/char str30;int index=0;void E();/E-TX;int E1();/X-+TX | evoid T();/T-FYint T1();/Y-*FY | eint F();/F-(E) | iFILE *fp;char cur;/*主函数*/int main()int len;int m;if(fp=fopen(source.txt,r)=NULL) coutcan not open the source file!endl; exit(1); cur=fgetc(fp); while(cur!=#) E(); coutendl;coutsuccessendl;return 0;/*/void E() T(); E1();/*/int E1()if(cur=+) cur=fgetc(fp);T();cout+ ;E1();else if(cur=-) cur=fgetc(fp); T(); cout- ; E1();return 0;/*/void T()F();T1();/*/int T1()if(cur=*) cur=fgetc(fp);F();cout* ;T1();else if(cur=/) cur=fgetc(fp); F(); cout/ ; T1();return 0;int F()if(cur=a)|(cur=A)|cur=_) for(int i=0;i20;i+) stri=0; index=0; strindex+=cur; cur=fgetc(fp); while(cur=a)|(cur=A)|cur=_|(cur=0) strindex+=cur; cur=fgetc(fp);coutstr;cout ;return NULL;else if (cur=0) for(int i=0;i20;i+) stri=0; index=0; while(cur=0) strindex+=cur; cur=fgetc(fp); if(cur=.) strindex+=cur; cur=fgetc(fp); while(cur=0) strindex+=cur; cur=fgetc(fp); coutstr; cout ; return NULL; else if(cur=a)|(cur=A)|cur=_) printf(error6n); exit(1); else coutstr; cout ; return NULL; else if (cur=() cur=fgetc(fp);E();if(cur=)cur=fgetc(fp);return 0;elseprintf(error3n);exit (1);elseprintf(error4n);exit(1);return 0; 程序运行结果:(截屏)输入:Source.txt文本(Aa+Bb)*(88.2/3)#输出:2) LL(1)#include #include #include #include #include using namespace std;struct Node1char vn;char vt;char s12;MAP22;/存储分析预测表每个位置对应的终结符,非终结符,产生式int k;char token30;int token_index=0;char G1212=E-TR,R-+TR,R-TR,R-e,T-FW,W-*FW,W-/FW,W-e,F-(E),F-i,F-n;/存储文法中的产生式 ,用R代表E,W代表T,e代表空/char VN6=E,R,T,W,F;/存储非终结符/char VT9=i,n,+,-,*,/,(,),#;/存储终结符char Select1212=(,i,n,+,-,),#,(,i,n,*,/,+,-,),#,(,i,n;/存储文法中每个产生式对应的select集合char Right128=-TR,-+TR,-TR,-e,-FW,-*FW,-/FW,-e,-(E),-i,-n;stack stak,stak1,stak2;char *Find(char vn,char vt)int i;for(i=0;ik;i+)if(MAPi.vn=vn& MAPi.vt=vt)return MAPi.s;return error;char *Analyse(char *token)char p,action10,output10;int i=1,j,k=0,l_act,m;while(!stak.empty()/判断栈中是否为空,若不空就将栈顶元素与分析表匹配进行相应操作stak.pop();stak.push(#);/栈底标志stak.push(E);/起始符号先入栈printf( 步骤 栈顶元素 输入串 推导所用产生式或匹配n);p=stak.top();while(p!=#)/查预测分析表将栈顶元素进行匹配,若栈顶元素与输入串匹配成功则向前匹配,否则生成式反序入栈printf(%7d ,i+);p=stak.top();/从栈中弹出一个栈顶符号,由p记录并输出stak.pop();printf(%6c ,p);for(j=0,m=0;j1;j-)stak.push(actionj);return ERROR;int Token() FILE *fp; char cur; int i,j; fp=fopen(source.txt,r); cur=fgetc(fp); while(cur!=EOF)/把用字母数字表示的输入串转换为token序列的表示方法if(cur=a)|(cur=A)|cur=_) cur=fgetc(fp); while(cur=a)|(cur=A)|cur=_|(cur=0) cur=fgetc(fp); tokentoken_index+=i; continue; else if (cur=0) while(cur=0) cur=fgetc(fp); if(cur=.) cur=fgetc(fp); while(cur=0) cur=fgetc(fp); tokentoken_index+=n; continue; else tokentoken_index+=cur; cur=fgetc(fp); continue; tokentoken_index=#;cout把文件中字符串用i表示,数字用n表示,转化后:;for(int index=0;index=token_index;index+) couttokenindex; coutendlendl; return 0;int main ()int i,j,l,m;for(i=0,k=0;i11;i+)/通过select集合生成预测分析表l=strlen

温馨提示

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

评论

0/150

提交评论