版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、第一章 什么是編譯器? 編譯程序的結(jié)構(gòu)分為幾個階段,各階段的任務(wù)是什么? 遍、編譯前端及編譯后端的含義? 編譯程序的生成方式有哪些? 第二章 1.寫一文法,使其語言是偶正整數(shù)的集合。 要求:(1)允許0打頭(2) 不允許0打頭 允許0開頭的偶正整數(shù)集合的文法 7 NT|D 7 NT|D 7 D|1|3|5|7|9 7 0|2|4|6|8 D (2)不允許0開頭的偶正整數(shù)集合的文法 E 7 NT|D 7 FT|G 7 D|1|3|5|7|9 7 2|4|6|8 7 N|0 7 D|0 G 2.證明下述文法 G 表達式是二義的。 表達式: 運算符: 解:可為句子 最右推導1 表達式 表達式 表達式
2、 表達式 表達式 最右推導2 表達式 表達式 表達式 表達式 表達式 3. =a|(表達式)| 表達式運算符表達式 =+|-|*|/ a+a*a構(gòu)造兩個不同的最右推導: 表達式 運算符 =表達式運算符表達式 * a 運算符 運算符 表達式 運算符 運算符 運算符 運算符 表達式* a =表達式運算符表達式 表達式運算符表達式 表達式運算符a 表達式* a a + a * a 給出生成下述語言的上下文無關(guān)文法: (1) anbnambm| n , m=0 (2) 1n0m1m0n| n , m=0 解:(1) anbnambm| n , m=0 S7 AA A7 aAb| 精品文庫 歡迎下載16
3、 1nOm1mOn| n, m=0 4 1S0|A A7 0A1| 第三章 1、構(gòu)造一個DFA它接收刀=a, b上所有滿足下述條件的字符串: 至少一個b直接跟在其右邊。 解: 已知刀=a, b,根據(jù)題意得出相應(yīng)的的正規(guī)式為: 根據(jù)正規(guī)式畫出相應(yīng)的 用子集法將其確定化 DFA M如下圖所示 (b*abb*)* 字符串中的每個 a都有 CD (b*abb*)* X b*abb* X 2 3 4 b 5 a b X,1,2,3,Y 4 2,3 4 一 5,6,1,2,3,Y 2,3 4 2,3 5,6,1,2,3,Y 4 6,1,2,3,Y 6,1,2,3,Y 4 6,1,2,3,Y I Ia Ib
4、 0 1 2 1 一 3 2 1 2 3 1 4 4 1 4 由DFA得狀態(tài)圖 順序重新命名 用最小化方法化簡得: DFA M 第四章 練習1:文法 V 7 N|NE GV: E 7 V|V+E 是否為LL(1)文法,如不是,如何將其改造成 解: LL(1)文法的基本條件是不含左遞歸和回溯(公共左因子) 7 i LL(1)文法。 ,而GV中含有回溯,所以先消 V 7 |E 7 |+E FIRST(A) 加入 FOLLOW(B),即 FOLLOW(B)=a, b, c, d ; FIRST(S) 加入 FOLLOW(B),即 FOLLOW(B)=a, b, c, d ; FOLLOW(B加入 F
5、OLLOW(A),即 FOLLOW(A)=a, b, c, d ; FOLLOW(B加入 FOLLOW(S),即 FOLLOW(S)=#, a, b, c, d ; 由 A7 BS|d 得: FIRST(BS) 由 B7 aA|bS|c 得: FIRST(aA) n FIRST(d) = a, b, c n d= n FIRST(bS) n FIRST(c) =a n b 由于文法Gs不存在形如3 7 的產(chǎn)生式,故無需求解形如 也即,文法 GS是一個LL(1)文法。 (2)由 Gs:S 7 BA FIRST(B)=a, b, c; FIRST(A)=a, b, c, d; A 7 BS|d B
6、 7 aA|bS|c 的 FOLLOW(B)=a, b, c, d ; FOLLOW(A)=a, b, c, d ; n c= O FIRST( a ) n FOLLOW(A的值。 除回溯得到文法 G V: G V :V 7 NV E7 VEE N7 i G V是LL(1)文法 由LL(1)文法的充要條件可證 練習2:有文法 Gs: B 7 aA|bS|c S 7 ba a 7 BS|d (1)證明文法G是LL(1)文法。 構(gòu)造LL(1)分析表。 (3)寫出句子adccd的分析過程 解:(1) 一個LL(1)文法的充要條件是:對每一個非終結(jié)符A的任何兩個不同產(chǎn)生式A7 a | 3,有下面的條件
7、成立: FIRST( a ) n FIRST( 3 )=; 若 3 *= ,則有 FIRST( a ) n FOLLOW(A) 對于文法Gs: S 7 BA A 7 BS|d B 7 aA|bS|c 其FIRST集如下: FIRST(B)=a, b, c; FIRST(A)=a, b, c, d; FIRST(S)=a, b, c 其FOLLOW如下: 首先,F(xiàn)OLLOW(S)=#; 對S7 ba有: 對A7 BS有: 對B7 aA有: 對B7 bS有: a b u d # S S7 BA S7 BA S7 BA A A7 BS A7 BS A7 BS A7 d B B7 aA B7 bS B
8、7 c c S S7 BA S7 BA S7 BA A A7 BS A7 BS A7 BS A7 d B7 aA B7 bS B7 c O FOLLOW(S)=#, a, b, c, d FIRST(S)=a, b, c 可構(gòu)造LL(1)預(yù)測分析表如下: (3)在分析表的控制下,句子adccd的分析過程如下: (1) 解: 非終結(jié)符 FIRSTVT 集 lastvt集 s a A ( a A ) a A ( , a A ) , St(T) Tt s Tt T,S (1) FIRSTVT - LASTVT 表 OPG文法。 第五章 1已知文法GS為: St a| A |(T)TtT,S|S 計算
9、 GS的 FIRSTVT和 LASTVT 構(gòu)造GS的算符優(yōu)先關(guān)系表并說明 GS是否為算符優(yōu)先文法。 給出輸入串(a,(a,a)#的算符優(yōu)先分析過程。 文法: T t T,S|S St a| A |(T) 展開為: St a StA (2)算符優(yōu)先關(guān)系表如下:表中無多重入口所以是算符優(yōu)先( (3)輸入串(a,(a,a) ) #的算符優(yōu)先分析過程為: 當前字 符 剩余輸入串 動作 E(a (N (N, #(N,( #(N,(a #(N,(N I(N,(N, (N,(N,a (N,(N,N (N,(N (N,(N) (N,N (N a ) ) ) ) ) ) # # a,(a,a)# ,(a,a)#
10、 (a,a)# (a,a)# a,a)# ,a)# a)# a)# )# )# )# )# # 第六章 例1:有文法:S 7 (L)|a L 給此文法配上語義動作子程序 的個數(shù)。如對于句子(a,(a,a), 解:加入新開始符號S和產(chǎn)生式 義如下: 產(chǎn)生式 Move in Move in Reduce: S 7 a Move in Move in Move in Reduce: S 7 a Move in Move in Reduce: S 7 a Reduce: T 7t,S Move in Reduce: S 7 (T) Reduce: T 7t,S Move in Reduce: S (T
11、) 7 L,S|S (或者說為此文法寫一個語法制導定義),它輸出配對括號 輸出是2。 S 7 S,設(shè)num為綜合屬性,代表值屬性,則語法制導定 S S S 7 (L) 7 a 7 L1,S 7 S 語義規(guī)則 prin t(S .num) S.nu m:=L. nu m+1 S. nu m:=0 L.num :=L1. nu m+S .num L.nu m:=S. num 例2:構(gòu)造屬性文法,能對下面的文法,只利用綜合屬性獲得類型信息。 D 7 L,id | L L7 T id T7 int | real 解:屬性文法 7 L,id | L L (語法制導)定義: 產(chǎn)生式語義規(guī)則 7 L,idD
12、.typ e:=L.t ype addt yp e(id.e ntry,L.t ype) 7 LD.t yp e:=L.t ype L.t yp e:=T.t ype addt yp e(id.e ntry,T.t ype) T.t ype:=in teger T.t yp e:=real 7 int 7 real 第七章 例1 :給出下面表達式的逆波蘭表示(后綴式): a*(-b+c) (2) if(x+y)*z=0 then s:=(a+b)*c else s:=a*b*c 解: (1) ab-c+* (2) xy+z*O=sab+c*:=sab*c*:= Y (注:Y表示 if-then
13、-else運算) 例 2:請將表達式-(a+b)*(c+d)-(a+b) 解: 分別表示成三元式、間接三元式和四元式序列。 三元式 間接三元式 (1) (+ a, b) 間接三元式序列 間接碼表 (+ c, d) (1) (+ a, b) (1) (3) (* (1), (2) (+ c, d) (2) (-(3), /) (3) (* (1), (2) (3) (+ a, b) (-(3), /) (4) (6) (- (4), (5) (5) (- (4), (1) (1) (5) 四元式 (1) (+, a, b, t1) (+, c, d, t2) (*, t1, t2, t3) (4
14、) (-, t3, /, t4) (+, a, b, t5) (6) (-, t4, t5, t6) 例3:請將下列語句 while (AD) then X:=Y+Z 翻譯成四元式 解: 假定翻譯的四元式序列從(100)開始: (100) if AD goto (104) (103) goto (100) (104) T : =Y+Z (105) X : =T (106) goto (100) (107) 例4:寫出for 解: 產(chǎn)生式 S T for E do S1 語句的翻譯方案 動作 S.begi n := n ewlabel S.first := n ewte mp S.last :=
15、 n ewte mp S.curr:= n ewte mp S.code:=ge n( S.first |ge n(S.last “ :=” E.i nit) “ :=” E.final) “if ” S.first ( ” |ge n( |ge n( S.curr |ge n( S.begi n |ge n( |S1.code |ge n( S.curr := succ(S.curr) |gen(“ goto ” S.begin) E T v:=i nitial to finalE.i nit := in itial. place E.final := fin al. place a ? “
16、if ” S.curr “ ” S.last S.first) ) “ ” S.Last “ goto ” S.next) “ goto ” S.next) 第八章 auto, local static 例1: C語言中規(guī)定變量標識符的定義可分為extern, extern static, 對五種存儲類所定義的每種變量,分別說明其作用域。 試給出適合上述存儲類變量的內(nèi)存分配方式。 符號表中登記的存儲類屬性,在編譯過程中支持什么樣的語義檢查。 和register 五種存儲類: (1) 解: (1) extern定義的變量,其作用域是整個C語言程序。 extern static定義的變量,其作用域
17、是該定義所在的C程序文件。 auto定義的變量,其作用域是該定義所在的例程。 local static定義的變量,其作用域是該定義所在的例程。且在退出該例程時,該變 量的值仍保留。 register定義的變量,其作用域與auto定義的變量一樣。這種變量的值,在寄存器 有條件時,可存放在寄存器中,以提高運行效率。 (2) 對extern變量,設(shè)置一個全局的靜態(tài)公共區(qū)進行分配。 對extern static 變量,為每個C程序文件,分別設(shè)置一個局部靜態(tài)公共區(qū)進行分配。 對auto和register變量,設(shè)定它們在該例程的動態(tài)區(qū)中的相對區(qū)頭的位移量。而例 程動態(tài)區(qū)在運行時再做動態(tài)分配。 對local
18、 static 變量,為每個具有這類定義的例程,分別設(shè)置一個內(nèi)部靜態(tài)區(qū)進行 分配。 (3) 實施標識符變量重復(fù)定義合法性檢查,及引用變量的作用域范圍的合法性檢查。 第九章 例1:下面的程序執(zhí)行時,輸出的a分別是什么?若參數(shù)的傳遞辦法分別為(1)傳名;(2)傳 地址;(3)得結(jié)果;4)傳值。 P rogram main (inpu t,out pu t); pro cedure p( x,y,z); begin y : =y+1; z : =z+x; en d; begin a : =2; b : =3; p (a+b,a,a); print a en d. 解: (1) 參數(shù)的傳遞辦法為 “傳
19、名”時, a 為9。 參數(shù)的傳遞辦法為 “傳地址”, a 為8。 參數(shù)的傳遞辦法為 “得結(jié)果”, a 為7。 參數(shù)的傳遞辦法為 “傳值”, a為2。 例2:過程參數(shù)的傳遞方式有幾種?簡述“傳地址”和“傳值”的實現(xiàn)原理。 解: 參數(shù)的傳遞方式有下述幾種:傳值,傳地址,傳名,得結(jié)果 “傳值”方式,這是最簡單的參數(shù)傳遞方法。即將實參計算出它的值,然后把它傳給被調(diào)過 程。具體來講是這樣的: 1. 形式參數(shù)當作過程的局部變量處理,即在被調(diào)過程的活動記錄中開辟了形參的存儲空 間,這些存儲位置即是我們所說的實參或形式單元。 2. 調(diào)用過程計算實參的值,并將它們的右值(r-value )放在為形式單元開辟的空
20、間中。 3. 被調(diào)用過程執(zhí)行時,就像使用局部變量一樣使用這些形式單元。 指向?qū)崊?“傳地址”方式,也稱作傳地址,或引用調(diào)用。調(diào)用過程傳給被調(diào)過程的是指針, 存儲位置的指針。 1. 如實參是一個名字或是具有左值的表達式,則左值本身傳遞過去。 2. 如實參是一個表達式,比方a+b或2,而沒有左值,則表達式先求值,并存入某一位 置,然后該位置的地址傳遞過去。 3. 被調(diào)過程中對形式參數(shù)的任何引用和賦值都通過傳遞到被調(diào)過程的指針被處理成間接 訪問。 例3:下面是一個 Pascal程序 P rogram PP (i npu t,out put) var K:in teger; fun cti on F(
21、N:i nteger):i nteger begin if N =0 the n F:=1 else F:=N * F(N-1); en d; begin K:=F(10); en d; 當?shù)诙?遞歸地)進入 F后,DISPLAY的內(nèi)容是什么?當時整個運行棧的內(nèi)容是什么? 解: 運行橫布局: 第十章 例1:何謂代碼優(yōu)化?進行優(yōu)化所需要的基礎(chǔ)是什么? 解: 而運 對代碼進行等價變換, 使得變換后的代碼運行結(jié)果與變換前代碼運行結(jié)果相同, 行速度加快或占用存儲空間減少,或兩者都有。 優(yōu)化所需要的基礎(chǔ)是在中間代碼生成之后或目標代碼生成之后。 例2:編譯過程中可進行的優(yōu)化如何分類?最常用的代碼優(yōu)化技術(shù)
22、有哪些? 解: 依據(jù)優(yōu)化所涉及的程序范圍,可以分為:局部優(yōu)化、循環(huán)優(yōu)化和全局優(yōu)化。 最常用的代碼優(yōu)化技術(shù)有 1.刪除多余運算2.代碼外提3.強度削弱4.變換循環(huán)控制條件 5.合并已知量與復(fù)寫傳 播6.刪除無用賦值 B: =3 D :=A+C E: =A*C F :=D+E G: =B*F H :=A+C I : =A*C J :=H+I K: =B*5 L :=K+J M =L B2: 例3:試對以下基本塊 解: 基本塊對應(yīng)的DAG如下: B: =3D: =A+C E: =A*C F : =D+E G: =B*F H : =A+C I : =A*C J : =H+I K: =B*5 L : =
23、K+J M =L 例1 一個編譯程序的代碼生成要著重考慮 (1) (2) 應(yīng)用DAG對它們進行優(yōu)化,并就以下兩種情況分別寫出優(yōu)化后的四元式序列: 假設(shè)只有 G L、M在基本塊后面還要被引用。 假設(shè)只有L在基本塊后面還要被引用。 些問題? 解: 代碼生成器的設(shè)計要著重考慮目標代碼的質(zhì)量問題,而衡量目標代碼的質(zhì)量主要從占 用空間和執(zhí)行效率兩個方面綜合考慮。 課后習題答案: P36-6 L(G)是09組成的數(shù)字串 (2)最左推導: N = ND = NDD = NDDD 二 DDDD = ODDD = O1DD= 012D二 0127 N = ND = 最右推導: N = ND NDD = DDD
24、= 5DD= 56D= 568 N7 = ND7= N27= ND27= N127= D127= 0127 ND N4 = D4= 34 ND N8 = ND8= N68= D68= 568 P36-8 文法: Et Tt Ft +T|E -T T E F T* F|T/ F (E)|i 最左推導: E = E *r = T +T= F +T= i +T=i +T* F = i +F* F = i +i *F = i +i *i E = T=T*F=F*F = i*F = i*( E)= i*( E +T)= i*( T +T)= i*( F +T) =i*(i +T)= i*( i +F)
25、= i*(i +i) 最右推導: E=E *Fr=E +T*F = E 4T*i = E +F*i = E +i*i = T 十 i*i=F +i*i=i+i*i E=T = F*T = F*F = F*( E)=F*(E +T)=F*(E+F)=F*(E +i) =F*( T +i) = F *( F +i) = F *( i +i)=i*( i 4i) 語法樹./* i+i+i i-i-i i+i*i P36-9 句子iiiei 有兩個語法樹: =iiiei S 二 iSeS= iSei = iiSei S 二 iS= iiSeS= iiSei = iiiei P64 - 7 (1) 1(
26、01) 101 歡迎下載17 0 1 X 1,2,3 1,2,3 2,3 2,3,4 2,3 2,3 2,3,4 2,3,4 2,3,5 2,3,4 2,3,5 2,3 2,3,4,Y 2,3,4,Y 2,3,5 2,3,4 最小化: 0,1,2,3,4,5, 6 0,1,2,3,4,51,2,4,6 0,1,234,5 0 =1,3,5 0,1,2,3,4, 5, 6 0,1,234 0 =1,3,5 0,1,2,3, 4, 5, 6 0,1,2,3。=1,30,1,2,31 =1,2,4 0,1,2,34, 5, 6 0,1。=10,1 =1,2 2,3。叫32,34 0, 1, 2,3,
27、 4, 5, 6 1 1 精品文庫 P64- 12 歡迎下載29 a b 0 0,1 1 0,1 0,1 1 1 0 給狀態(tài)編號: a b 0 1 2 1 1 2 2 0 3 3 3 3 A 0,1 1 2,3a =0,3 0,1, 2, 3 0,1 b =2 2,3b =3 (b) 最小化: 0,1, 2,3,4,5 0,1a =10,1b =2,4 2,3,4,5a =1,3,0,52,3,4,5b =2,3,4,5 2,4a =1,02,4b =3,5 3,5a =3,53,5b =2,4 0,1, 2,4, 3,5 = 1 = 1,0 0,1b =2,4 2,4b =3,5 0,1a
28、2,4a 3,5 P 81 - 1 (1)按照T,S的順序消除左遞歸 G(S) ST aFI 仃) T T ST Tt ,ST I 遞歸子程序: p rocedure S; begin if sym=a or sym= the n abva nee else if sym=( the n begi n advance;T; if sym=) the n adva nee; else error; end else error end; p roeedure T; begin ST en d; proeedure T : begin if sym=, the n begi n advanee;
29、ST end end; 其中: sym:是輸入串指針I(yè)P所指的符號 advanee:是把IP調(diào)至下一個輸入符號 error:是出錯診察程序 FIRST(S)=a,A,( FIRST(T)=a,A,( FIRST()=, FOLLOW(S)=),# FOLLOW(T)=) FOLLOWT )=) 預(yù)測分析表 a A ( ) J # S St a St a St (T) T Tt st Tt ST Tt st T, Tt s Tt ,ST 是LL(1)文法 P 81 - 2 文法: E E T T F F P T E + E F T T | P F * F (E ) (1) FIRST(E)=(,
30、a,b,A FIRST(E)=+, FIRST(T)=(,a,b,A FIRST(T)=(,a,b,A, FIRST(F)=(,a,b,A FIRST(F)=*, FIRST( P)=(,a,b,A FOLLOW(E)=#,) FOLLOW(E)=#,) FOLLOW(T)=+,),# FOLLOW(T)=+,),# FOLLOW(F)=(,a,b,A,+,),# FOLLOW(F)=(,a,b,A,+,),# FOLLOW( P)=*,(,a,b,A,+,),# 考慮下列產(chǎn)生式: EJ +E|s T J T|e F J *F 2 Pt (E)|A|a|b FIRST(+E) n FIRST(
31、 )=+ n = 0 FIRST(+E) n FOLLOW(E)=+ n #,)=0 n = 0 n +,),#=0 n FiRST( )=* n = 0 n FOLLOW(F)=* n (,a,b,A,+,),#=0 n FIRST(a) n FIRST(b) n FIRST()= 0 FIRST(T) n FIRST( )=(,a,b, FIRST(T) n FOLLOW(T)=(,a,b,A FIRST(*F) FIRST(*F) FIRST(E) 所以,該文法式LL(1)文法. + ( ) a b A # E Et TE Et TE Et TE Et TE E Et+ E E J E
32、J T Tt FT Tt FT Tt FT Tt ft T Tt s Tt T Tt E Tt T Tt T Tt T Tt F Ft PF Ft PF Ft PF Ft PF F Ft s FT*F F J F J F J F J FT s FT P PT (E) Pt a Pt b PT A P rocedure E; begin if sym=( or sym=a or sym=b or sym- the n beg in T; E end else error end p rocedure E; begin if sym=+ the n beg in adva nee; E end e
33、lse if sym) and sym# the n error end p rocedure T; begin if sym=( or sym=a or sym=b or sym- the n beg in F; T end else error end p rocedure T; begin if sym=( or sym=a or sym=b or sym= then T else if sym=* the n error end p rocedure F; begin if sym=( or sym=a or sym=b or sym= the n beg in P; F end el
34、se error end p rocedure F; begin if sym=* the n beg in adva nee; F end end p rocedure P; begin if sym-a or sym-b or sym= the n adva nee else if sym=( the nbegin advanee; E; if sym=) the n adva nee else error end else error end; P133- 1 E= E +T二 E+ T* F 短語:E+T*F, T*F, 直接短語:T*F 句柄:T*F P133- 2 文法: St a
35、|A|(T) Tt T,S|S (1)最左推導: s= (T)= (T,S)=(S,S)= (a,S)= (a,(T)= (a,(T,S)二(a,(S,S)= (a,(a,S)= (a,(a,a) S= (T,S)二(S,S)= (T),S)= (T,S),S)二(T,S,S),S)= (S,S,S),S)二(T), S,S),S) =(T,S), S, S), S) = ( S,S), S,S),S) = (a,S),S,S),SM (a,a), S,S), S) =(a,a),A ,S),S)= (a,a),A ,(T), S)= (a,a),A ,(S), S)= (a,a),A ,(a
36、), S) 二(a,a),A ,(a), a) 最右推導: S= (T)= (T,S)= (T,(T)= (T,(T,S)二(T,(T,a)= (T,(S,a)= (T,(a,a) 二(S,(a,a)二(a,(a,a) S二(T,S)二(T,a)二(S,a)= (T),a)= (T,S),a)= (T,(T),a)二(T,(S),a) 二(T,(a),a)= (T,S,(a),a)= (T】,(a), a)= (S, ,(a),a)= (T), ,(a), a) 二(T,S),A ,(a), a)二(T,a),A ,(a),a)= (S,a),A ,(a),a)二(aa)】 ,(a),a) (
37、a,a),(a),a) (S),A,(a),a) (T, ar,(a),a) (LSV,(a),a) (IL,A,(a),a) (S,A,(a),a) (T,A,(a),a) (T,( (T,( (T,( (LS,(a),a) aj),a) S),a) T),a) (TS),a) (IL,a) (S,a) (TS) (T)_ S “移進-歸約”過程: 步驟棧 輸入串 (a,a),A,(a),a)# (a,a),A,(a),a)# 動作 預(yù)備 進 2 #( (a,a),A,(a),a)# 進 3 #( a,a),A,(a),a)# 進 4 #(a ,a),A,(a),a)# 進 5 #(S ,a
38、),A,(a),a)# 歸 6 #(T ,a),A,(a),a)# 歸 7 #(T, a),A,(a),a)# 進 8 #(T,a ),A,(a),a)# 進 9 #(T,S ),A,(a),a)# 歸 10 #(T ),(a),a)# 歸 11 #(T) ,八,(a),a)# 進 12 #(S ,(a),a)# 歸 13 #(T ,(a),a)# 歸 14 #(T, A,(a),a)# 進 15 #(T,A ,(a),a)# 進 16 #(T,S ,(a),a)# 歸 17 #(T ,(a),a)# 歸 18 #(T, (a),a)# 進 19 #(T,( a),a)# 進 20 #(T,(
39、a ),a)# 進 21 #(T,(S ),a)# 歸 22 #(T,(T ),a)# 歸 23 #(T,(T) ),a)# 進 24 #(T,S ),a)# 歸 25 #(T ),a)# 歸 26 #(T) ,a)# 進 27 #(S ,a)# 歸 28 #(T ,a)# 歸 29 #(T, a)# 進 30 #(T,a )# 進 31 #(T,S )# 歸 32 #(T )# 歸 33 #(T) # 進 34 #S # 歸 #( P133- 3 (1) FIRSTVT(S)=a,A,( FIRSTVT(T)=,a,A,( LASTVT(S)=a,A,) LASTVT(T)=,a,A,) a A ( ) J a A ( = J G6是算符文法,并且是算符優(yōu)先文法 (3)優(yōu)先函數(shù) 棧 輸入字符串 動作 # (a,(a,a) )# 預(yù)備 #( a, (a,a)# 進 #(a ,(a,a)# 進 #(s ,(a,a)# 歸 #(t ,(a,a)# 歸 # (t, (a,a)# 進 # (t,( a,a) # 進 # ( t, ( a ,a)# 進 # ( t, ( s ,a)# 歸 # ( t, ( t ,a)# 歸 # ( t, ( t, a)# 進 # (t, (t,a )# 進 # (t, (t,s )# 歸 # ( t, ( t )# 歸 # (
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年行政事業(yè)單位國有房屋出租協(xié)議(綠色能源研發(fā)中心)2篇
- 二零二五年旋挖鉆機銷售代理合同3篇
- 二零二五年度駕校培訓師資承包合同3篇
- 2025年教育機構(gòu)宣傳片拍攝制作服務(wù)協(xié)議模板2篇
- 2025年箱涵施工合同及施工現(xiàn)場安全管理規(guī)范2篇
- 2025年環(huán)保型印刷品生產(chǎn)與采購合作協(xié)議3篇
- 2025年區(qū)塊鏈數(shù)字資產(chǎn)管理平臺合作協(xié)議
- 2025年價格調(diào)整協(xié)議攝影器材租賃合同
- 2025年借殼上市資金募集協(xié)議
- 2025年金錢贊助合同
- 2024-2025學年成都高新區(qū)七上數(shù)學期末考試試卷【含答案】
- 定額〔2025〕1號文-關(guān)于發(fā)布2018版電力建設(shè)工程概預(yù)算定額2024年度價格水平調(diào)整的通知
- 2025年浙江杭州市西湖區(qū)專職社區(qū)招聘85人歷年高頻重點提升(共500題)附帶答案詳解
- 《數(shù)學廣角-優(yōu)化》說課稿-2024-2025學年四年級上冊數(shù)學人教版
- “懂你”(原題+解題+范文+話題+技巧+閱讀類素材)-2025年中考語文一輪復(fù)習之寫作
- 2025年景觀照明項目可行性分析報告
- 2025年江蘇南京地鐵集團招聘筆試參考題庫含答案解析
- 2025年度愛讀書學長參與的讀書項目投資合同
- 電力系統(tǒng)分析答案(吳俊勇)(已修訂)
- 化學-河北省金太陽質(zhì)檢聯(lián)盟2024-2025學年高三上學期12月第三次聯(lián)考試題和答案
- 期末復(fù)習試題(試題)-2024-2025學年四年級上冊數(shù)學 北師大版
評論
0/150
提交評論