版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、1第四章第四章: :詞法分析詞法分析Lexical AnalysisLexical Analysis234第二遍第二遍單詞串單詞串取單詞取單詞優(yōu)點優(yōu)點: 結構清晰、各遍功能單一結構清晰、各遍功能單一缺點:效率低缺點:效率低562. 詞法分析程序的輸出形式詞法分析程序的輸出形式-單詞的內部形式單詞的內部形式7If (3, if)I (1,8910111213=a,b=a,b,上的正規(guī)式和相應的正規(guī)集如下上的正規(guī)式和相應的正規(guī)集如下:14例例 2 2:令令=A,B,0,1=A,B,0,1,則,則:例例 3 3:令令=d,.,e,+,-=d,.,e,+,-,寫出,寫出上的無符號數(shù)的正則上的無符號數(shù)的
2、正則式式15例例 3 3:令:令=d,.,e,+,-=d,.,e,+,-,則,則上的無符號數(shù)上的無符號數(shù)的正則式表示為:的正則式表示為:164.2.3 4.2.3 程序設計語言中的正則表達式程序設計語言中的正則表達式例1:數(shù)字集D=0,1,9和字母集L=A|Z|a|z例2:整常數(shù)的集合IntC可表示為:例3:實常數(shù)的集合RealC可表示為:“”讀作“定義定義為為”17例5:由/開始并以Eol(行結束符)結束的注釋,可用正則表達式定義為如下:例4:由字母、數(shù)字和下劃線組成,由字母為首,以字母或數(shù)字結束,且下劃線不相連的標識符之集IDE可表示為如下:18 192021v 結點代表狀態(tài),用圓圈表示。
3、v 狀態(tài)之間用箭弧連結,箭弧上的標記(字符)代表在射出結點(即箭弧始結點)狀態(tài)下可能出現(xiàn)的輸入字符或字符類。v 一張轉換圖只包含有限個狀態(tài)(即有限個結點),其中一個為初態(tài),至少一個為終態(tài)(雙圈表示)。狀態(tài)轉換圖狀態(tài)轉換圖狀態(tài)轉換圖是設計詞法分析程序的一種好途徑。狀態(tài)轉換圖是設計詞法分析程序的一種好途徑。狀態(tài)轉換圖,一張有限方向圖,規(guī)定:狀態(tài)轉換圖,一張有限方向圖,規(guī)定:22例3:識別整數(shù)的轉換圖(如右上圖)例2:識別標識符的轉換圖(如左下圖)字母字母01字母或數(shù)字字母或數(shù)字數(shù)字數(shù)字01數(shù)字數(shù)字表示:在狀態(tài)1下,若輸入字符為x,則讀進x,并轉換到狀態(tài)2; 若輸入字符為y,則讀進y,并轉換到狀態(tài)3
4、。132xy例1:2324它所對應的狀態(tài)轉移矩陣如圖:一個一個DFADFA可用一個矩陣表示,該矩陣的行表示狀態(tài),可用一個矩陣表示,該矩陣的行表示狀態(tài),列表示輸入字符,矩陣元素表示列表示輸入字符,矩陣元素表示(s,a)(s,a)的值,這個的值,這個矩陣稱狀態(tài)轉移矩陣。矩陣稱狀態(tài)轉移矩陣。狀態(tài)狀態(tài)ab01213221333325狀態(tài)轉換圖可用于識別(或接受)一定的字符串狀態(tài)轉換圖可用于識別(或接受)一定的字符串aaa|b031bbab226a1a2an27NFA的形式定義為的形式定義為:28ABijABijkA|BijA*ijABijijkANFA替換規(guī)則替換規(guī)則NFA允許允許邊出現(xiàn)邊出現(xiàn)29=a
5、,b, 上所有含有兩個相繼的上所有含有兩個相繼的a或兩或兩個相繼的個相繼的b的字的集合的字的集合用用NFA表示如下表示如下:NFA M=( 0,1,2,3,4,5,6,7 , a,b , , 0 , 7 )其中其中如上(不可省略)(a|b)*aa|bb(a|b)*aa576bbab01234ba初態(tài)初態(tài)終態(tài)終態(tài)(a|b)* (aa|bb) (a|b)* 3031v()合并)合并v符號合并符號合并轉換函數(shù)初態(tài)NFA M (S,S0,F)SS的子集多值映射S0 S非空初態(tài)DFA M (S,s0,F)SS單值映射s0S唯一的初態(tài)NFA允許允許邊出現(xiàn)邊出現(xiàn)()合并:)合并:如果有S1S2,則把S2狀態(tài)
6、合并到S1狀態(tài)。32例1:NFA轉換成DFA (符號合并)例2:設計一個DFA,其輸入字母表是0,1,它能接受以0開始,以1結尾的所有序列。aa3cb012a01,2cb30,10ZCSAB1解:解:根據題意,得出相應的正則式:0(0|1)*1 得狀態(tài)轉換圖(NFA)如下:3301stateDFA stateSSSABCS,ABCS,ABCABCBCBCZ ABC,BC,BCZS,ABC,BC,BCZBCBCBCZ BC,BCZS,ABC,BC,BCZBCZBCBCZ BCZS,ABC,BC,BCZ(S,)=;(S,0)=?(S,0)=A; (A,)=B; (B,)=C; (C,)=; 0,10ZCSAB134得狀態(tài)轉換圖(DFA)如下:000SCA101B1000SBCZABC101BC1在DFA中,所有含有NFA的終態(tài)的狀態(tài)作為DFA的終態(tài)DFA M=( S,A,B,C , 0,1 , , S , C )其中其中如上(不可省略)353637初態(tài)初態(tài)3839404142v將所有DFA的終態(tài)與其它狀態(tài)劃分成兩個子集G1,G2;v分別從兩個子集G1,G2中尋找等價狀態(tài)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年度當涂縣事業(yè)單位公開招聘工作人員43名筆試備考題庫及答案解析
- 2026年金溪縣公開選調事業(yè)單位工作人員【19人】考試備考題庫及答案解析
- 2026云南省上海師范大學附屬官渡實驗學校(中學)招聘1人筆試參考題庫及答案解析
- 2026上半年貴州事業(yè)單位聯(lián)考貴州省第二人民醫(yī)院招聘12人筆試參考題庫及答案解析
- 2026年葡萄酒感官品評技術培訓
- 2026南昌市勞動保障事務代理中心招聘7名勞務派遣駕駛員考試備考試題及答案解析
- 2026上半年貴州事業(yè)單位聯(lián)考貴陽貴安招聘402人筆試備考試題及答案解析
- 2026年內部審計流程規(guī)范培訓
- 2026四川師范大學考核招聘事業(yè)單位人員126人筆試備考試題及答案解析
- 2026山西浮山縣太岳新能源有限責任公司招聘1人考試備考題庫及答案解析
- 大數(shù)據安全技術與管理
- 2026青島海發(fā)國有資本投資運營集團有限公司招聘計劃筆試備考試題及答案解析
- 2026年北大拉丁語標準考試試題
- 鼻飼技術操作課件
- 臨床護理操作流程禮儀規(guī)范
- 2025年酒店總經理年度工作總結暨戰(zhàn)略規(guī)劃
- 空氣栓塞課件教學
- 置景服務合同范本
- 隧道掛防水板及架設鋼筋臺車施工方案
- 2025年國家市場監(jiān)管總局公開遴選公務員面試題及答案
- 肌骨康復腰椎課件
評論
0/150
提交評論