资源描述:
《北邮编译原理语法分析》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、编译原理语法分析班级:学号:姓名:ytinrete程序设计2题目:语法分析程序的设计与实现。实验内容:编写语法分析程序,实现对算术表达式的语法分析。要求所分析算术表达式由如下的文法产生。实验要求:在对输入表达式进行分析的过程中,输出所采用的产生式。方法1:编写递归调用程序实现自顶向下的分析。方法2:编写LL(1)语法分析程序,要求如下。(1)编程实现算法4.2,为给定文法自动构造预测分析表。(2)编程实现算法4.1,构造LL(1)预测分析程序。方法3:编写语法分析程序实现自底向上的分析,要求如下。(1)构造识别所有活前缀的DFA。
2、(2)构造LR分析表。(3)编程实现算法4.3,构造LR分析程序。方法4:利用YACC自动生成语法分析程序,调用LEX自动生成的词法分析程序。方法2:编写LL(1)语法分析程序首先对文法进行处理,预存文法的拓广文法,非终结符的FIRST集和FOLLOW集。其次编程实现算法4.2,为给定文法自动构造分析表。最后输入待处理字符串,通过实现的算法4.1,利用分析表分析出字符串,能够接受则返回接受,否则返回错误。源代码:#include#include#include#include<
3、cstring>#include#include#includeusingnamespacestd;stringoriginal[9]={//保存原文法"E->E+T","E->E-T","E->T","T->T*F","T->T/F","T->F","F->i","F->(E)","F->n"};stringG[11]={//拓广文法"E->TA","A->+TA","A->-TA","A->e","T->FB","B->*FB","B->/FB","B->e","F->(E)
4、","F->i","F->n"};stringFIRST[5]={//first集"E:(in",//E"A:+-e",//A"T:(in",//T"B:*/e",//B"F:(in"//F};stringFOLLOW[5]={//follow集"E:)$",//E"A:)$",//A"T:+-)$",//T"B:+-)$",//B"F:+-*/)$",//F};charVN[5]={'E','A','T','B','F'};//存储非终结符charVT[9]={'i','n','+','-','*','/','(',')','$
5、'};//存储终结符typedefstructBlock{charvn;//非终结符charvt;//终结符strings;//产生式}block;//存储分析预测表每个位置对应的终结符,非终结符,产生式blocktable[45];//5*9=45charis_vt(chara)//是否为非终结符,不是返回'x'{for(inti=0;i<5;i++){if(a==VN[i])return'x';}if(isalpha(a))//是字母return'i';if(isdigit(a))//是数字return'n';for(inti
6、=0+2;i<9;i++){if(a==VT[i])returna;}}intfind_table(charX,chara)//查找是否存在符合的产生式{for(inti=0;i<45;i++){if(table[i].vn==X&&table[i].vt==is_vt(a))if(0!=table[i].s.size())returni;elsereturn999;//error项}return999;}voidLL_one(stringtemp){stackST;//栈ST.push('$');//初始化压入栈ST
7、.push('E');cout<<"栈"<<"输入"<<"输出"<99)cout<<":";elseif(j>9)cout<<":";elsecout<<":";//输出stackt_ST;//栈chart_char;inti2=ST.size();for(inti1=0;i18、19、";for(int