版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、第三講 程序語言的語法描述,作業(yè):P36(6,7,8) 其中6(2)做0127 8(1)做i+i*i,上下文無關(guān)文法語法范疇完全獨立于這種范疇可能出現(xiàn)的環(huán)境,1)文法與語言文法 上下文無關(guān)文法G是一個四元式(VT,VN,S,P)。其中 VT:非空集,每個元素叫終結(jié)符 VN:非空有限集,每個元素稱為非終結(jié)符 S: 非終結(jié)符,叫做開始符號 P: 產(chǎn)生式集(有限), 形式為 P-&
2、gt;?, 其中 P? VN, ??(VT ?VN)* 注意: 開始符S至少必須在某個產(chǎn)生式的左部出現(xiàn)一次. P-> ?1 P-> ?2 … P-> ?n 可以縮寫為 P-> ?1 | ?2 | …| ?n 每個?i 也叫 P 的一個侯選式. 討論中多以大寫字母表示非終結(jié)符,,語言 上下文無關(guān)文法定義語言的辦法: 從文法的開始符出發(fā),
3、反復連續(xù)使用產(chǎn)生式,對非終結(jié)符實施替換和展開.E.G. 文法 E->E+E |E*E | (E) | i (P28) 據(jù)規(guī)則: E ->(E),我們說: 從“E”可以直接推出“(E)”,記為 E=>(E); 對“(E)”中“E”再用 E->E+E 便有: (E)=>(E+E), 即由 “E” 可以推出(E+E). 表示為: E=>(E)=>(E+E),,基本術(shù)語(P29)
4、 學員閱讀直接推出推導可推導出?1 =+> ?n?1 =*> ?n 文法的句型 文法G的句子全體形成它的語言 L(G)= {?| S=*> ?且??VT*}最左推導(最右推導) E=>(E)=>(E+E) => (E*E+E) => (i*E+E) => (i*i+E) => (i*i+i),,2) 語法樹及二義性語法樹(P31圖
5、2.2,侯選式中自左至右的每個符號對應一個新結(jié)點) 包含了最左、最右推導,但不含所有可能推導 E ( E ) E + E文法的二義性
6、 E * E i i i,,,,,,,,,,,,,文法的二義性 文法二義性 若一文法中存在某個句子,它有兩個不同的最左 (最右)推導,或者說一文法存在某個句子對應兩 棵不同的語法樹. 例: P31圖2
7、.2, P32圖2.3 (i*i+i) 語言的二義性 某語言由不同文法刻畫 兩種二義性有何不同,,P28的表達式文法可以通過規(guī)定*,+優(yōu)先順序,結(jié)合規(guī)則而構(gòu)造一無二義的文法. E -> T | E+T 概念分層思想 T -> F | T*F F -> (E) | i,,對上下文無關(guān)文法的兩點限制文法中不含任何 P->P 形式的產(chǎn)生式
8、 (會產(chǎn)生二義?)每個非終結(jié)符都有用處 即存在 S =*> ?? P ?, 則必有 ??VT*, 使得 P =*> ?.,,3) 形式語言鳥瞰 Chomsky 將文法分為四類: 0, 1, 2, 30: 每個產(chǎn)生式 ? ? ?滿足: ??(VN ?VT)*且至少含一個非終結(jié)符, 而 ? ?(VN ?VT)*.1: 每個產(chǎn)生式 ? ? ?滿足:
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 面向VHDL算法級行為描述的程序語言編譯方法研究.pdf
- c++程序語言設計
- 程序設計簡介(程序語言簡介.ppt)
- 概率認知邏輯程序語言的研究.pdf
- 基于程序語言機制的信息釋放策略.pdf
- 函數(shù)式并行程序語言研究.pdf
- autolisp程序語言在房產(chǎn)測量中的應用
- 移動進程作為程序語言庫函數(shù)的研究.pdf
- 《程序語言綜合課程設計》實驗報告
- 基于程序語言的完整性安全模型.pdf
- c++程序語言教程 第二章
- 框架時序邏輯程序語言MSVL的形式語義.pdf
- 高級程序語言課程設計題及參考資料
- 函數(shù)式程序語言與傳值進程演算的關(guān)系研究.pdf
- 網(wǎng)絡課程開發(fā)的研究與實踐——以《高級程序語言(JAVA)》課程為例.pdf
- 基于共享資源聲明的并行程序語言的設計與前端實現(xiàn).pdf
- 第二章高級語言及其語法描述-read
- 程序語言課程設計---一元多項式簡單的計算器
- 程序語言課程設計--任意兩個高次多項式的加法和乘法運算
- 基于VBA程序語言實現(xiàn)Ansys軟件對連續(xù)剛構(gòu)橋數(shù)值分析的參數(shù)化.pdf
評論
0/150
提交評論