




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
編譯原理實(shí)驗(yàn)講義ver0.4實(shí)驗(yàn)一C_minus語言詞法剖析器的設(shè)計(jì)(6學(xué)時(shí))【目的】設(shè)計(jì)一個(gè)簡(jiǎn)單的詞法剖析器,進(jìn)而進(jìn)一步加深對(duì)詞法剖析器工作原理的理解。【要求】1、該個(gè)詞法剖析器要求起碼能夠辨別以下幾類單詞:a.重點(diǎn)字:elseifintreturnvoidwhile共6個(gè),全部的重點(diǎn)字都是保存字,而且一定是小寫;b.表記符:辨別與C語言詞法例定相一致的表記符,經(jīng)過以下正則表達(dá)式定義:ID=letter(letter|digit)*;c.常數(shù):NUM=(+|-|ε)digitdigit*(.digitdigit*|ε)(e(+|-|ε)digitdigit*|ε),letter=a|..|z|A|..|Z|,digit=0|..|9,包含整數(shù),如123,-123,+123等;小數(shù),如123.45,+123.45,-123.45;科學(xué)計(jì)數(shù)法表示的常數(shù),如+1.23e3,-2.3e-9;d.專用符號(hào):+-*/<<=>>===!==;,( )[]{}/**/;2、剖析器的輸入為由上述幾類單詞組成的程序,輸出為該段程序的機(jī)內(nèi)表示形式,即重點(diǎn)字、運(yùn)算符、界線符變成其對(duì)應(yīng)的機(jī)內(nèi)符,常數(shù)使用二進(jìn)制形式,表記符使用相應(yīng)的表記符表指針表示。3、詞法剖析器應(yīng)該能夠指出源程序中的詞法錯(cuò)誤,如不行識(shí)其他符號(hào)、錯(cuò)誤的詞法等?!痉椒ㄅc參照】第一給出全部單詞的正規(guī)式(或正規(guī)文法)表示,而后將其轉(zhuǎn)變成NFA,再將NFA確立化、最小化,獲得最簡(jiǎn)的DFA,依據(jù)DFA編寫詞法剖析器的代碼?!緦?shí)驗(yàn)環(huán)境和工具】本實(shí)驗(yàn)不限制現(xiàn)所使用的開發(fā)工具以及運(yùn)轉(zhuǎn)環(huán)境。實(shí)驗(yàn)二遞歸降落剖析器的設(shè)計(jì)(6學(xué)時(shí))【目的】使用遞歸子程序法設(shè)計(jì)一個(gè)語法剖析程序,理解自頂向下剖析方法的原理,掌握手工編寫語法剖析程序的方法?!疽蟆?、使用遞歸降落剖析算法剖析表達(dá)式文法:exp::=expaddopterm|termaddop::=+|-term::=termmulopfactor|factormulop::=*|/factor::=(exp)|number此中number能夠是多位的十進(jìn)制數(shù)字串(整數(shù)即可),所以這里還需要一個(gè)小的詞法剖析器來獲得number的值。2、該詞法剖析器以子程序形式出現(xiàn),當(dāng)需要進(jìn)行詞法剖析時(shí)進(jìn)行調(diào)用;3、能夠辨別正確和錯(cuò)誤的表達(dá)式;4、在進(jìn)行語法剖析的過程中,計(jì)算輸入表達(dá)式的值?!痉椒ㄅc參照】第一將上述文法改寫成EBNF形式,依據(jù)遞歸降落剖析算法基本思想編寫程序?!緦?shí)驗(yàn)環(huán)境和工具】本實(shí)驗(yàn)不限制現(xiàn)所使用的開發(fā)工具以及運(yùn)轉(zhuǎn)環(huán)境。1實(shí)驗(yàn)三算符優(yōu)先剖析法剖析器的設(shè)計(jì)(6學(xué)時(shí))【目的】設(shè)計(jì)一個(gè)算符優(yōu)先剖析器,理解優(yōu)先剖析方法的原理。【要求】使用算符優(yōu)先剖析算法剖析下邊的文法:E’→#E#E→E+T|T→T*F|FF→P^F|PP→(E)|i此中i能夠看作是一個(gè)終結(jié)符,無需作詞法剖析。詳細(xì)要求以下:1.假如輸入符號(hào)串為正確句子,顯示剖析步驟,包含剖析棧中的內(nèi)容、優(yōu)先關(guān)系、輸入符號(hào)串的變化狀況;假如輸入符號(hào)串不是正確句子,則指示犯錯(cuò)地點(diǎn)?!痉椒ā康谝唤Y(jié)構(gòu)算符優(yōu)先關(guān)系表,而后依據(jù)算符優(yōu)先剖析算法編寫程序?!緦?shí)驗(yàn)環(huán)境和工具】本實(shí)驗(yàn)不限制現(xiàn)所使用的開發(fā)工具以及運(yùn)轉(zhuǎn)環(huán)境。//依據(jù)算符優(yōu)先文法的剖析規(guī)則求得終結(jié)符優(yōu)先關(guān)系表//+*^i()#//+><<<<>>//*>><<<>>//^>><<<>>//i>>>>>//(<<<<<=//)>>>>>//#<<<<<=#include<stdlib.h>#include<string.h>#include<stdio.h>#include<dos.h>charyouxian[7][7];//算符優(yōu)先關(guān)系數(shù)組voidmain( ){{//將算符優(yōu)先關(guān)系寄存在算符優(yōu)先關(guān)系數(shù)組里youxian[0][0]='>';youxian[0][1]='<';youxian[0][2]='<';youxian[0][3]='<';youxian[0][4]='<';2youxian[0][5]='>';youxian[0][6]='>';//______________________________________________________________youxian[1][0]='>';youxian[1][1]='>';youxian[1][2]='<';youxian[1][3]='<';youxian[1][4]='<';youxian[1][5]='>';youxian[1][6]='>';//_______________________________________________________________youxian[2][0]='>';youxian[2][1]='>';youxian[2][2]='<';youxian[2][3]='<';youxian[2][4]='<';youxian[2][5]='>';youxian[2][6]='>';//_______________________________________________________________youxian[3][0]='>';youxian[3][1]='>';youxian[3][2]='>';youxian[3][3]='$';//無優(yōu)先關(guān)系的用$表示youxian[3][4]='$';youxian[3][5]='>';youxian[3][6]='>';//_________________________________________________________________youxian[4][0]='<';youxian[4][1]='<';youxian[4][2]='<';youxian[4][3]='<';youxian[4][4]='<';youxian[4][5]='=';youxian[4][6]='$';//_________________________________________________________________youxian[5][0]='>';youxian[5][1]='>';youxian[5][2]='>';youxian[5][3]='$';youxian[5][4]='$';youxian[5][5]='>';youxian[5][6]='>';//__________________________________________________________________youxian[6][0]='<';3youxian[6][1]='<';youxian[6][2]='<';youxian[6][3]='<';youxian[6][4]='<';youxian[6][5]='$';youxian[6][6]='=';//______________________________________
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 標(biāo)準(zhǔn)汽車租賃合同協(xié)議
- 農(nóng)業(yè)灌溉系統(tǒng)設(shè)計(jì)與安裝手冊(cè)
- 少年英雄傳記的讀后感
- 無人機(jī)在物流領(lǐng)域的應(yīng)用合作協(xié)議
- 環(huán)境管理體系認(rèn)證服務(wù)合同
- 零售業(yè)行業(yè)-銷售數(shù)據(jù)統(tǒng)計(jì)表
- 成長(zhǎng)的煩惱故事評(píng)析報(bào)告
- 小學(xué)語文成語故事解讀
- 西餐原料知識(shí)培訓(xùn)課件
- 種子委托生產(chǎn)合同
- 結(jié)婚函調(diào)報(bào)告表
- GB/T 21671-2018基于以太網(wǎng)技術(shù)的局域網(wǎng)(LAN)系統(tǒng)驗(yàn)收測(cè)試方法
- 公司休假銷假單模板
- 經(jīng)鼻腸梗阻導(dǎo)管護(hù)理課件
- 統(tǒng)計(jì)學(xué)調(diào)查報(bào)告(共5篇)
- 外墻蜘蛛人施工方案
- 海洋工程裝備技術(shù)專業(yè)人才培養(yǎng)方案(高職)
- 教科版三年級(jí)科學(xué)下冊(cè) 《各種各樣的運(yùn)動(dòng)》 教學(xué)課件
- 浙江杭州余杭區(qū)余杭街道招考聘用編外人員16人(必考題)模擬卷及答案
- 腹腔穿刺術(shù)(僅供參考)課件
- 免費(fèi)推廣軟件大全匯總
評(píng)論
0/150
提交評(píng)論