如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
输入:3+4*6输出:27(当然中间包括LR(1)语法分析过程程序提供主要为了给大家提供一些方便,你懂得。。。呵呵如有问题,QQ:718561468来自:大连理工大学软件学院#include<iostream>usingnamespacestd;#include<stack>#include<queue>#include<fstream>#include<string>stringAnalyzeChart[16][11]={//LR文法的分析表"s5","e1","e1","s4","e2","e1","1","2","3","e1","e1","e3","s6","e1","e3","e2","acc","error","error","error","s7","e1","e6","r2","s8","e6","r2","r2","error","error","error","r2","s9","e6","r4","r4","e6","r4","r4","error","error","error","r4","r4","s5","e1","e1","s4","e2","e1","10","2","3","e1","e1","e5","r6","r6","e3","r6","r6","error","error","error","r6","r6","s5","e1","e1","s4","e2","e1","error","11","3","e1","e1","s5","e1","e1","s4","e2","e1","error","12","3","e1","e1","s5","e1","e1","s4","e2","e1","error","error","13","e1","e1","s5","e1","e1","s4","e1","e1","error","error","14","e1","e1","e3","s6","e1","e3","s15","r3","error","error","error","s9","e1","e6","r1","s8","e6","r1","r1","error","error","error","r1","s9","e6","r7","s8","e6","r7","r7","error","error","error","r7","s9","e6","r3","r3","e6","r3","r3","error","error","error","r3","r3","e6","r8","r8","e6","r8","r8","error","error","error","r8","r8","e6","r5","r5","e6","r5","r5","error","error","error","r5","r5",};stack<float>digit;queue<float>digit1;queue<int>inputid;char*FinalSymbol[6]={"i","+","*","(",")","#"//终结符};char*UnfinalSymbol[5]={"E","E'","T","T'","F"//非终结符};stack<char>ufstack;//状态栈voidinitialize(){ufstack.push('0');inputid.push(0);}char*keyword[6]={"for","if","then","else","while","do"};intflag1=-1,flag2=-1;typedefstructsign{intline;inttoken;chartemp[10];inti;};voidreset(sign&s){s.i=0;memset(s.temp,'$',10);s.token=-1;}boolis_key_word(sign&s){inti,r;for(i=0;i<6;i++){r=memcmp(s.temp,keyword[i],s.i);if(r==0){s.token=i+1;returntrue;break;}}returnfalse;}boolis_id(sign&s){inti;boolb=false;if((s.temp[0]>='a'&&s.temp[0]<='z')|(s.temp[0]>='A'&&s.temp[0]<='Z