




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、中間代碼生成-四元式設(shè)計(jì)文檔實(shí)驗(yàn)任務(wù): 在實(shí)驗(yàn)4的基礎(chǔ)上,完成以下描述賦值語(yǔ)句和算數(shù)表達(dá)式文法GA的語(yǔ)法制導(dǎo)生成中間代碼四元式的過(guò)程。 A-V:=E V- E,E+T|E-T|T T,T*F|T/F|F F,(E)| 說(shuō)明: 標(biāo)識(shí)符的定義參見(jiàn)實(shí)驗(yàn)一 程序的功能描述 從文件中讀入表達(dá)式,輸出其四元式的結(jié)果序列 本程序只能生成賦值語(yǔ)句及算數(shù)表達(dá)式中間代碼的四元式 不能生成邏輯表達(dá)式及其他復(fù)雜語(yǔ)句中間代碼的四元式,其功能還需要進(jìn)一步完善。 程序結(jié)構(gòu)描述 打開文件 成功 N Y 結(jié)束 調(diào)用scan()函數(shù)從文件讀入表達(dá)式 輸出所讀入的表達(dá)式 調(diào)用生成四元式函數(shù) siyuanshi() 表達(dá)式中是否有括
2、號(hào) N Y 處理括號(hào)內(nèi)的 處理乘除加減和賦值運(yùn)算 sum=0 N Y 輸出成功 輸出錯(cuò)誤提示 結(jié)束 程序測(cè)試方案 測(cè)試用例一: d=a+b*(3*n)/(b-a) 測(cè)試用例二: x=x*(x+y-(x-y)/(z+x)-y) 實(shí)驗(yàn)總結(jié) 此程序基本達(dá)到了實(shí)驗(yàn)要求,能夠生成簡(jiǎn)單的賦值及算數(shù)表達(dá)式中間代碼的四元式,但其功能實(shí)在是過(guò)于簡(jiǎn)單。 第一次調(diào)試通過(guò)后程序還存在以下不足: (1) 此程序只能從文件中讀入一個(gè)表達(dá)式,讀入多個(gè)則會(huì)出錯(cuò); (2) 所讀入的表達(dá)式中若含有多于一個(gè)括號(hào),程序會(huì)出錯(cuò); (3) 括號(hào)內(nèi)若多于一個(gè)表達(dá)式則會(huì)出錯(cuò); (4) 在測(cè)試用例二中的分析過(guò)程明顯是錯(cuò)誤的,這足以看出程序的漏
3、洞很多 但經(jīng)過(guò)進(jìn)一步優(yōu)化算法,以上問(wèn)題基本解決,但程序中仍然存在很多不足,例如時(shí)間效率和空間效率方面做的還不夠好,要改善這些不足還需要進(jìn)一步完善程序,在以后的學(xué)習(xí)生活中我會(huì)根據(jù)所學(xué)知識(shí)的不斷深入而不斷完善此程序,爭(zhēng)取使其功能更加強(qiáng)大。 經(jīng)過(guò)這次實(shí)驗(yàn)我更加深刻的理解了生成中間代碼的算法思想,及時(shí)的將所學(xué)知識(shí)用于實(shí)踐,更加深刻的掌握了所學(xué)知識(shí)。 附錄 #include #include #include using namespace std; #define MAX 100 int m=0,sum=0;/sum用于計(jì)算運(yùn)算符的個(gè)數(shù) /m用于標(biāo)記輸入表達(dá)式中字符的個(gè)數(shù) char JG=A; cha
4、r strMAX;/用于存輸入表達(dá)式 int token=0;/左括號(hào)的標(biāo)志 /*用于更改計(jì)算后數(shù)組中的值*/ void change(int e) int f=e+2; char ch=strf; if(ch=A&ch=Z) for(int l=0;l=A&stre=Z) for(int i=0;im;i+) if(stri=stre) stri=JG; void chengchuchuli(int i,int m) i+; for( ;i=m-1;i+)/處理乘除運(yùn)算 if(stri=*|stri=/) cout(stri stri-1 stri+1 JG)endl; change(i-1
5、); stri-1=stri=stri+1=JG; sum-; JG=(char)(int)JG+; void jiajianchuli(int j,int m) j+; for( ;j=m-1;j+)/處理加減運(yùn)算 if(strj=+|strj=-) cout(strj strj-1 strj+1 JG)endl; change(j-1); strj-1=strj=strj+1=JG; sum-; JG=(char)(int)JG+; /*掃描一遍從文件中讀入表達(dá)式*/ void scan(FILE *fin) int pMAX; char ch=a; int c=-1,q=0; while
6、(ch!=EOF) ch=getc(fin); while(ch= |ch=n|ch=t) ch=getc(fin);/消除空格和換行符 strm+=ch; if(ch=|ch=+|ch=-|ch=*|ch=/) sum+; else if(ch=() p+c=m-1; else if(ch=) q=m-1; chengchuchuli(pc,q);/從左括號(hào)處理到又括號(hào) jiajianchuli(pc,q); JG=(char)(int)JG-; strpc=strm-1=JG; c-; JG=(char)(int)JG+; /*對(duì)表達(dá)是進(jìn)行處理并輸出部分四元式*/ void siyuans
7、hi() for(int i=0;i=m-1;i+)/處理乘除運(yùn)算 if(stri=*|stri=/) cout(stri stri-1 stri+1 JG)endl; change(i-1); stri-1=stri=stri+1=JG; sum-; JG=(char)(int)JG+; for(int j=0;j=m-1;j+)/處理加減運(yùn)算 if(strj=+|strj=-) cout(strj strj-1 strj+1 JG)endl; change(j-1); strj-1=strj=strj+1=JG; sum-; JG=(char)(int)JG+; for(int k=0;k=m-1;k+)/處理賦值運(yùn)算 if(strk=) JG=(char)(int)-JG; cout(strk strk+1 strk-1)endl; sum-; change(k+1); strk-1=JG; /*主函數(shù)*/ void main() char inMAX; /用于接收輸入輸出文件名 FILE *fin; /用于指向輸入輸出文件的指針 coutin; coutendl; if (fin=fopen(in,r)=NULL) /判斷輸入文件名是否正確 coutendl打開詞法分析輸入文件出錯(cuò)!endl; cout四元式如下:endl;
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025至2030中國(guó)自動(dòng)微孔板清洗機(jī)行業(yè)產(chǎn)業(yè)運(yùn)行態(tài)勢(shì)及投資規(guī)劃深度研究報(bào)告
- 2025至2030中國(guó)腰背肌訓(xùn)練器行業(yè)市場(chǎng)深度分析及發(fā)展趨勢(shì)與投資報(bào)告
- 2025至2030中國(guó)脂肪乳行業(yè)市場(chǎng)現(xiàn)狀分析及競(jìng)爭(zhēng)格局與投資發(fā)展報(bào)告
- 2025至2030中國(guó)膠印設(shè)備行業(yè)市場(chǎng)發(fā)展分析及競(jìng)爭(zhēng)格局與投資前景報(bào)告
- 2025至2030中國(guó)胃藥行業(yè)發(fā)展趨勢(shì)分析與未來(lái)投資戰(zhàn)略咨詢研究報(bào)告
- 2025至2030中國(guó)聚酰亞胺板行業(yè)市場(chǎng)現(xiàn)狀分析及競(jìng)爭(zhēng)格局與投資發(fā)展報(bào)告
- 2025至2030中國(guó)聚乙烯醇(PVA)薄膜行業(yè)產(chǎn)業(yè)運(yùn)行態(tài)勢(shì)及投資規(guī)劃深度研究報(bào)告
- 燃?xì)廨啓C(jī)領(lǐng)域新革命:氫儲(chǔ)能與行業(yè)耦合策略研究
- 2025至2030中國(guó)網(wǎng)絡(luò)演藝行業(yè)市場(chǎng)深度研究及發(fā)展前景投資可行性分析報(bào)告
- 2025至2030中國(guó)缷船機(jī)行業(yè)市場(chǎng)發(fā)展分析與發(fā)展趨勢(shì)及投資風(fēng)險(xiǎn)報(bào)告
- GB/T 17989.2-2020控制圖第2部分:常規(guī)控制圖
- 建設(shè)項(xiàng)目安全設(shè)施‘三同時(shí)’課件
- 2022語(yǔ)文課程標(biāo)準(zhǔn):“語(yǔ)言文字積累與梳理”任務(wù)群解讀及實(shí)操
- DB15T 489-2019 石油化學(xué)工業(yè)建設(shè)工程技術(shù)資料管理規(guī)范
- 內(nèi)蒙古自治區(qū)通遼市各縣區(qū)鄉(xiāng)鎮(zhèn)行政村村莊村名居民村民委員會(huì)明細(xì)及行政區(qū)劃代碼
- 螺旋溜槽安裝標(biāo)準(zhǔn)工藝
- 2022年人教版六年級(jí)下冊(cè)語(yǔ)文期末考試卷
- 《土地開發(fā)整理項(xiàng)目預(yù)算編制暫行辦法》
- 安徽省評(píng)議公告的中小學(xué)教輔材料零售價(jià)格表
- 德龍自卸車合格證掃描件(原圖)
- 西子otis梯oh con6423中文調(diào)試手冊(cè)
評(píng)論
0/150
提交評(píng)論