SLR分析器实验(编译原理).doc

SLR分析器实验(编译原理).doc

ID:60779170

大小:216.00 KB

页数:4页

时间:2020-12-18

SLR分析器实验(编译原理).doc_第1页
SLR分析器实验(编译原理).doc_第2页
SLR分析器实验(编译原理).doc_第3页
SLR分析器实验(编译原理).doc_第4页
资源描述:

《SLR分析器实验(编译原理).doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、SLR(1)分析器源代码如下:#include#includechar*action[6][4]={"S2#","r3#","r3#","r3#",/*ACTION表*/NULL,NULL,NULL,"acc","S2#","r3#","r3#","r3#",NULL,"S5#","S4#",NULL,NULL,"r1#","r1#","r1#",NULL,"r2#","r2#","r2#"};intgoto1[6][1]={1,0,3,0,0,0};/*GOTO表*/charvt[4]={'a','b','d','#

2、'};/*存放非终结符*/charvn[1]={'A'};/*存放终结符*/char*LR[4]={"S->A#","A->aAd#","A->aAb#","A->#"};/*存放产生式*/inta[10];charb[10],c[10],c1;inttop1,top2,top3,top,m,n;voidmain(){intg,h,i,j,k,l,p,y,z,count;charx,copy[10],copy1[10];top1=0;top2=0;top3=0;top=0;a[0]=0;y=a[0];b[0]='#';count=0;z=0;printf(

3、"请输入表达式:");do{scanf("%c",&c1);c[top3]=c1;top3=top3+1;}while(c1!='#');printf("步骤t状态栈tt符号栈tt输入串ttACTIONtGOTO");do{y=z;m=0;n=0;/*y,z指向状态栈栈顶*/g=top;j=0;k=0;x=c[top];count++;printf("%dt",count);while(m<=top1){/*输出状态栈*/printf("%d",a[m]);m=m+1;}printf("tt");while(n<=top2){/*

4、输出符号栈*/printf("%c",b[n]);n=n+1;}printf("tt");while(g<=top3){/*输出输入串*/printf("%c",c[g]);g=g+1;}printf("tt");while(x!=vt[j]&&j<=2)j++;if(j==2&&x!=vt[j]){printf("error");return;}if(action[y][j]==NULL){printf("error");return;}elsestrcpy(copy,action[y][j]);if(copy[0]=='S'){/*处理

5、移进*/z=copy[1]-'0';top1=top1+1;top2=top2+1;a[top1]=z;b[top2]=x;top=top+1;i=0;while(copy[i]!='#'){printf("%c",copy[i]);i++;}printf("");}if(copy[0]=='r'){/*处理归约*/i=0;while(copy[i]!='#'){printf("%c",copy[i]);i++;}h=copy[1]-'0';strcpy(copy1,LR[h]);while(copy1[0]!=vn[k])k++;l=strlen(L

6、R[h])-4;top1=top1-l+1;top2=top2-l+1;y=a[top1-1];p=goto1[y][k];a[top1]=p;b[top2]=copy1[0];z=p;printf("t");printf("%d",p);}}while(action[y][j]!="acc");printf("acc");}

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。