![實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第1頁(yè)](http://file4.renrendoc.com/view5/M01/22/2D/wKhkGGZvrdqATnDLAACL7LDKjEY269.jpg)
![實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第2頁(yè)](http://file4.renrendoc.com/view5/M01/22/2D/wKhkGGZvrdqATnDLAACL7LDKjEY2692.jpg)
![實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第3頁(yè)](http://file4.renrendoc.com/view5/M01/22/2D/wKhkGGZvrdqATnDLAACL7LDKjEY2693.jpg)
![實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第4頁(yè)](http://file4.renrendoc.com/view5/M01/22/2D/wKhkGGZvrdqATnDLAACL7LDKjEY2694.jpg)
![實(shí)驗(yàn)四-非遞歸預(yù)測(cè)分析_第5頁(yè)](http://file4.renrendoc.com/view5/M01/22/2D/wKhkGGZvrdqATnDLAACL7LDKjEY2695.jpg)
版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 滁州成人高考數(shù)學(xué)試卷
- 預(yù)制界樁制作施工方案
- 磨煤機(jī)檢修施工方案
- 主題班會(huì)向中考沖刺五篇
- 2025年度物流設(shè)備租賃合同規(guī)范文本下載
- 2025年度河北房地產(chǎn)項(xiàng)目招投標(biāo)代理合同
- 2025年度智能倉(cāng)儲(chǔ)管理倉(cāng)單質(zhì)押融資擔(dān)保合同范本
- 2025年度專業(yè)車牌租賃及押金管理合同
- 冀教版數(shù)學(xué)七年級(jí)上冊(cè)《5.1 一元一次方程》聽(tīng)評(píng)課記錄3
- 2025年度航空航天技術(shù)合同協(xié)議保密協(xié)議書(shū)
- 高原鐵路建設(shè)衛(wèi)生保障
- 家具廠各崗位責(zé)任制匯編
- 顳下頜關(guān)節(jié)盤復(fù)位固定術(shù)后護(hù)理查房
- 硝苯地平控釋片
- 四川省瀘州市2019年中考物理考試真題與答案解析
- 部編版語(yǔ)文六年級(jí)下冊(cè)全套單元基礎(chǔ)??紲y(cè)試卷含答案
- 提高檢驗(yàn)標(biāo)本合格率品管圈PDCA成果匯報(bào)
- 2023年保險(xiǎn)養(yǎng)老地產(chǎn)行業(yè)分析報(bào)告
- 世界古代史-對(duì)接選擇性必修(真題再現(xiàn)) 高考?xì)v史一輪復(fù)習(xí)
- 保險(xiǎn)公司防火應(yīng)急預(yù)案
- 動(dòng)物檢疫技術(shù)-動(dòng)物檢疫的分類(動(dòng)物防疫與檢疫技術(shù))
評(píng)論
0/150
提交評(píng)論