實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第1頁(yè)
實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第2頁(yè)
實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第3頁(yè)
實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第4頁(yè)
實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第5頁(yè)
已閱讀5頁(yè),還剩4頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

《編譯原理實(shí)驗(yàn)》—LR分析器院、系(部)計(jì)算機(jī)科學(xué)與技術(shù)學(xué)院專業(yè)及班級(jí)計(jì)算機(jī)科學(xué)與技術(shù)專業(yè)1403班學(xué)號(hào)1408030322姓名朱浩日期2017年5月29日

一、實(shí)驗(yàn)?zāi)康呐c任務(wù)設(shè)計(jì)一個(gè)非遞歸預(yù)測(cè)分析器,實(shí)現(xiàn)對(duì)表達(dá)式語(yǔ)言的分析,理解自上而下語(yǔ)法分析方法的基本思想,掌握設(shè)計(jì)非遞歸預(yù)測(cè)分析器的基本方法。二、實(shí)驗(yàn)要求建立文法及其LL(1)分析表表示的數(shù)據(jù)結(jié)構(gòu),設(shè)計(jì)并實(shí)現(xiàn)相應(yīng)的預(yù)測(cè)分析器,對(duì)源程序經(jīng)詞法分析后生成的二元式代碼流進(jìn)行預(yù)測(cè)分析,如果輸入串是文法定義的句子則輸出“是”,否則輸出“否”。三、文法描述及其LL(1)分析表表達(dá)式語(yǔ)言(XL)的語(yǔ)法規(guī)則如下:程序→表達(dá)式;|表達(dá)式;程序表達(dá)式→表達(dá)式+項(xiàng)|項(xiàng)項(xiàng)→項(xiàng)*因式|因式因式→num_or_id|(表達(dá)式)將該語(yǔ)言的文法轉(zhuǎn)換為如下的LL(1)文法:prgm→expr;prgm’8term→factorterm’prgm’→prgm9term’→*factorterm’prgm’→ε10term’→εexpr→termexpr’11factor→(expr)expr→ε12factor→numexpr’→+termexpr’13system_goal→prgmexpr’→ε該LL(1)文法的LL(1)分析表如下:TNNum+*();#prgm111prgm’2223expr4455expr’677term88term’1091010factor1211system_goal131313對(duì)文法中每個(gè)文法符號(hào)指定一個(gè)常數(shù)值,符號(hào)編碼表如下:文法符號(hào)常數(shù)值備注char*action[10][3]={"S3#","S4#",NULL,/*ACTION表*/NULL,NULL,"acc","S6#","S7#",NULL,"S3#","S4#",NULL,"r3#","r3#",NULL,NULL,NULL,"r1#","S6#","S7#",NULL,NULL,NULL,"r3#","r2#","r2#",NULL,NULL,NULL,"r2#"};intgoto1[10][2]={1,2,/*QOTO表*/0,0,0,5,0,8,0,0,0,0,0,9,0,0,0,0,0,0};charvt[3]={'a','b','#'};/*存放非終結(jié)符*/charvn[2]={'S','B'};/*存放終結(jié)符*/char*LR[4]={"E->S#","S->BB#","B->aB#","B->b#"};/*存放產(chǎn)生式*/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("--------------編譯原理課程設(shè)計(jì)--------------\n");printf("-------------------汪鑫-------------------\n");printf("----------------20170527----------------\n");printf("----------------請(qǐng)輸入表達(dá)式--------------\n");do{scanf("%c",&c1);c[top3]=c1;top3=top3+1;}while(c1!='#');printf("步驟\t狀態(tài)棧\t\t符號(hào)棧\t\t輸入串\t\tACTION\tGOTO\n");do{y=z;m=0;n=0;/*y,z指向狀態(tài)棧棧頂*/g=top;j=0;k=0;x=c[top];count++;printf("%d\t",count);while(m<=top1){/*輸出狀態(tài)棧*/printf("%d",a[m]);m=m+1;}printf("\t\t");while(n<=top2){/*輸出符號(hào)棧*/printf("%c",b[n]);n=n+1;}printf("\t\t");while(g<=top3){/*輸出輸入串*/printf("%c",c[g]);g=g+1;}printf("\t\t");while(x!=vt[j]&&j<=2)j++;if(j==2&&x!=vt[j]){printf("error\n");return;}if(action[y][j]==NULL){printf("error\n");return;}elsestrcpy(copy,action[y][j]);if(copy[0]=='S'){/*處理移進(jìn)*/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("\n");}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(LR[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\n",p);}}while(action[y][j]!="acc");printf("acc\n");getchar();}七、實(shí)驗(yàn)結(jié)果八、實(shí)驗(yàn)總結(jié)通過(guò)這次LR0分析器的實(shí)驗(yàn),實(shí)現(xiàn)對(duì)詞

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論