編譯原理題庫(kù)_第1頁(yè)
編譯原理題庫(kù)_第2頁(yè)
編譯原理題庫(kù)_第3頁(yè)
編譯原理題庫(kù)_第4頁(yè)
編譯原理題庫(kù)_第5頁(yè)
已閱讀5頁(yè),還剩19頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、第一章§ 什么是編譯器?§ 編譯程序的結(jié)構(gòu)分為幾個(gè)階段,各階段的任務(wù)是什么?§ 遍、編譯前端及編譯后端的含義?§ 編譯程序的生成方式有哪些?第二章§ 1. 寫(xiě)一文法,使其語(yǔ)言是偶正整數(shù)的集合。§ 要求:(1)允許0打頭 (2) 不允許0打頭解:(1)允許0開(kāi)頭的偶正整數(shù)集合的文法 ENT|D TNT|D ND|1|3|5|7|9 D0|2|4|6|8(2)不允許0開(kāi)頭的偶正整數(shù)集合的文法 ENT|D TFT|G ND|1|3|5|7|9 D2|4|6|8 FN|0 GD|02.證明下述文法G表達(dá)式是二義的。表達(dá)式=a|(表達(dá)

2、式)|表達(dá)式運(yùn)算符表達(dá)式運(yùn)算符=+|-|*|/解:可為句子a+a*a構(gòu)造兩個(gè)不同的最右推導(dǎo): 最右推導(dǎo)1 表達(dá)式Þ表達(dá)式運(yùn)算符表達(dá)式Þ表達(dá)式運(yùn)算符aÞ表達(dá)式* aÞ表達(dá)式運(yùn)算符表達(dá)式* aÞ 表達(dá)式運(yùn)算符a * aÞ表達(dá)式+ a * aÞ a + a * a最右推導(dǎo)2 表達(dá)式Þ表達(dá)式運(yùn)算符表達(dá)式Þ表達(dá)式運(yùn)算符表達(dá)式運(yùn)算符表達(dá)式Þ表達(dá)式運(yùn)算符表達(dá)式運(yùn)算符 aÞ表達(dá)式運(yùn)算符表達(dá)式 * aÞ 表達(dá)式運(yùn)算符a * aÞ表達(dá)式+ a * aÞ a + a * a3.

3、 給出生成下述語(yǔ)言的上下文無(wú)關(guān)文法: (1) anbnambm| n,m>=0 (2) 1n0m1m0n| n,m>=0解: (1) anbnambm| n,m>=0 SAAAaAb| (2) 1n0m1m0n| n,m>=0S1S0|AA0A1|第三章1、構(gòu)造一個(gè)DFA,它接收=a, b上所有滿足下述條件的字符串:字符串中的每個(gè)a都有至少一個(gè)b直接跟在其右邊。解:已知=a, b,根據(jù)題意得出相應(yīng)的的正規(guī)式為: (b*abb*)*根據(jù)正規(guī)式畫(huà)出相應(yīng)的DFA M,如下圖所示用子集法將其確定化XY(b*abb*)*XYb*abb*1eeXYb123456bbaeeeeeeI

4、IaIbX,1,2,3,Y42,345,6,1,2,3,Y2,342,35,6,1,2,3,Y46,1,2,3,Y6,1,2,3,Y46,1,2,3,YIIaIb01213212314414由DFA得狀態(tài)圖 用最小化方法化簡(jiǎn)得:0,1,2,3,4,按順序重新命名DFA M10243aaaabbbbb 0312aaabbb第四章練習(xí)1:文法GV: VN|NE EV|V+E Ni 是否為L(zhǎng)L(1)文法,如不是,如何將其改造成LL(1)文法。解:LL(1)文法的基本條件是不含左遞歸和回溯(公共左因子),而GV中含有回溯,所以先消除回溯得到文法GV: GV: VNV V|E EVE E|+E Ni由L

5、L(1)文法的充要條件可證GV是LL(1)文法練習(xí)2:有文法Gs: SBA ABS|d BaA|bS|c(1)證明文法G是LL(1)文法。(2)構(gòu)造LL(1)分析表。(3)寫(xiě)出句子adccd的分析過(guò)程解:(1)一個(gè)LL(1)文法的充要條件是:對(duì)每一個(gè)非終結(jié)符A的任何兩個(gè)不同產(chǎn)生式A|,有下面的條件成立: FIRST()FIRST()=; 若*Þ, 則有FIRST()FOLLOW(A)=對(duì)于文法Gs: SBA ABS|d BaA|bS|c其FIRST集如下: FIRST(B)=a, b, c; FIRST(A)=a, b, c, d; FIRST(S)=a, b, c。其FOLLOW集

6、如下:首先, FOLLOW(S)=#;對(duì)SBA有: FIRST(A)加入FOLLOW(B), 即FOLLOW(B)=a, b, c, d ;對(duì)ABS有:FIRST(S)加入FOLLOW(B), 即FOLLOW(B)=a, b, c, d ;對(duì)BaA有:FOLLOW(B)加入FOLLOW(A), 即FOLLOW(A)=a, b, c, d ;對(duì)BbS有:FOLLOW(B)加入FOLLOW(S), 即FOLLOW(S)=#, a, b, c, d ;由ABS|d得: FIRST(BS) FIRST(d) = a, b, c d = ;由BaA|bS|c得: FIRST(aA) FIRST(bS)

7、FIRST(c) =a b c= 。由于文法Gs不存在形如 的產(chǎn)生式,故無(wú)需求解形如FIRST()FOLLOW(A)的值。也即,文法GS是一個(gè)LL(1)文法。(2) 由Gs:SBA ABS|d BaA|bS|c的FIRST(B)=a, b, c; FOLLOW(B)=a, b, c, d ; FIRST(A)=a, b, c, d; FOLLOW(A)=a, b, c, d ;FIRST(S)=a, b, c。 FOLLOW(S)=#, a, b, c, d 可構(gòu)造LL(1)預(yù)測(cè)分析表如下: abcd#SSBASBASBA  AABSABSABSAd B

8、BaABbSBc  SSBASBASBA  AABSABSABSAd BBaABbSBc  (3)在分析表的控制下,句子adccd的分析過(guò)程如下:第五章1 已知文法GS為:Sa|(T) TT,S|S (1) 計(jì)算GS的FIRSTVT和LASTVT。(2) 構(gòu)造GS的算符優(yōu)先關(guān)系表并說(shuō)明GS是否為算符優(yōu)先文法。(3) 給出輸入串 (a,(a,a)#的算符優(yōu)先分析過(guò)程。解:文法:Sa|(T) TT,S|S 展開(kāi)為: SaSS(T) TT,S TS(1) FIRSTVT - LASTVT表 非終結(jié)符 FIRSTVT集 LASTVT

9、集 S a ( a ) T a ( , a ) , (2)算符優(yōu)先關(guān)系表如下: 表中無(wú)多重入口所以是算符優(yōu)先(OPG)文法。  a (),#a(),# (3) 輸入串(a,(a,a))# 的算符優(yōu)先分析過(guò)程為:棧 當(dāng)前字符 剩余輸入串動(dòng)作 #(#(a#(N#(N,#(N,(#(N,(a#(N,(N#(N,(N,#(N,(N,a#(N,(N,N#(N,(N#(N,(N)#(N,N#(N#(N)#N(a,(a,a)# a,(a,a)#,(a,a)#(a,a)#(a,a)#a,a)#,a)#a)#a)#)#)#)#)#Move inMove inReduce: SaMove inMove

10、inMove inReduce: SaMove inMove inReduce: SaReduce: TT,SMove inReduce: S(T)Reduce: TT,SMove inReduce: S(T) 第六章例1:有文法: S(L)|a LL,S|S 給此文法配上語(yǔ)義動(dòng)作子程序(或者說(shuō)為此文法寫(xiě)一個(gè)語(yǔ)法制導(dǎo)定義),它輸出配對(duì)括號(hào)的個(gè)數(shù)。如對(duì)于句子(a,(a,a),輸出是2。解:加入新開(kāi)始符號(hào)S'和產(chǎn)生式S'S,設(shè)num 為綜合屬性,代表值屬性,則語(yǔ)法制導(dǎo)定義如下: 產(chǎn)生式 語(yǔ)義規(guī)則 S'S print(S.num) S(L) S.num:=L.num+1 Sa

11、 S.num:=0 LL1,S L.num:=L1.num+S.num LS L.num:=S.num例2:構(gòu)造屬性文法,能對(duì)下面的文法,只利用綜合屬性獲得類(lèi)型信息。 D L,id | L L T id T int | real解:屬性文法(語(yǔ)法制導(dǎo))定義: 產(chǎn)生式 語(yǔ)義規(guī)則 D L,id D.type:=L.type addtype(id.entry,L.type) D L D.type:=L.type L T id L.type:=T.type addtype(id.entry,T.type) T int T.type:=integer T real T.type:=real第七章例1:給

12、出下面表達(dá)式的逆波蘭表示(后綴式):(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*0=sab+c*:=sab*c*:=¥(注:¥表示if-then-else 運(yùn)算)例2:請(qǐng)將表達(dá)式-(a+b)*(c+d)-(a+b)分別表示成三元式、間接三元式和四元式序列。解: 三元式 間接三元式 (1) (+ a, b) 間接三元式序列 間接碼表 (2) (+ c, d) (1) (+ a, b)(1) (3) (* (1), (2) (2) (+ c, d)(2) (4) (- (3), /) (

13、3) (* (1), (2) (3) (5) (+ a, b) (4) (- (3), /) (4) (6) (- (4), (5) (5) (- (4), (1) (1) (5) 四元式 (1) (+, a, b, t1) (2) (+, c, d, t2) (3) (*, t1, t2, t3) (4) (-, t3, /, t4) (5) (+, a, b, t5) (6) (-, t4, t5, t6) 例3:請(qǐng)將下列語(yǔ)句 while (A<B) do if (C>D) then X:=Y+Z 翻譯成四元式解:假定翻譯的四元式序列從(100)開(kāi)始:(100) if A<

14、;B goto(102)(101) goto (107)(102) if C>D goto(104)(103) goto (100)(104) T=Y+Z(105) X=T(106) goto (100)(107)例4:寫(xiě)出for 語(yǔ)句的翻譯方案解:產(chǎn)生式 動(dòng)作S for E do S1 S.begin := newlabel S.first := newtemp S.last := newtemp S.curr:= newtemp S.code:=gen(S.first “:=” E.init) |gen(S.last “:=” E.final) |gen(“if” S.first “

15、>” S.last “goto” S.next) |gen(S.curr “:=” S.first) |gen(S.begin “:” ) |gen(“if ” S.curr “>” S.Last “goto” S.next) |S1.code |gen(S.curr := succ(S.curr) |gen(“goto” S.begin)E v:=initial to final E.init := initial.place E.final := final.place第八章例1:C語(yǔ)言中規(guī)定變量標(biāo)識(shí)符的定義可分為extern, extern static, auto, loc

16、al static和register五種存儲(chǔ)類(lèi):(1) 對(duì)五種存儲(chǔ)類(lèi)所定義的每種變量,分別說(shuō)明其作用域。(2) 試給出適合上述存儲(chǔ)類(lèi)變量的內(nèi)存分配方式。(3) 符號(hào)表中登記的存儲(chǔ)類(lèi)屬性,在編譯過(guò)程中支持什么樣的語(yǔ)義檢查。解:(1) extern 定義的變量,其作用域是整個(gè)C 語(yǔ)言程序。 extern static 定義的變量,其作用域是該定義所在的C 程序文件。 auto 定義的變量,其作用域是該定義所在的例程。 local static 定義的變量,其作用域是該定義所在的例程。且在退出該例程時(shí),該變量的值仍保留。 register 定義的變量,其作用域與auto 定義的變量一樣。這種變量的值

17、,在寄存器有條件時(shí),可存放在寄存器中,以提高運(yùn)行效率。(2) 對(duì)extern 變量,設(shè)置一個(gè)全局的靜態(tài)公共區(qū)進(jìn)行分配。 對(duì)extern static 變量,為每個(gè)C 程序文件,分別設(shè)置一個(gè)局部靜態(tài)公共區(qū)進(jìn)行分配。 對(duì)auto 和register 變量,設(shè)定它們?cè)谠摾痰膭?dòng)態(tài)區(qū)中的相對(duì)區(qū)頭的位移量。而例程動(dòng)態(tài)區(qū)在運(yùn)行時(shí)再做動(dòng)態(tài)分配。 對(duì)local static 變量,為每個(gè)具有這類(lèi)定義的例程,分別設(shè)置一個(gè)內(nèi)部靜態(tài)區(qū)進(jìn)行分配。(3) 實(shí)施標(biāo)識(shí)符變量重復(fù)定義合法性檢查,及引用變量的作用域范圍的合法性檢查。第九章例1:下面的程序執(zhí)行時(shí),輸出的a分別是什么?若參數(shù)的傳遞辦法分別為(1)傳名;(2)傳地址

18、;(3)得結(jié)果;4)傳值。 program main (input,output);procedure p(x,y,z); beginy=y+1; z=z+x;end; begina=2; b=3; p(a+b,a,a); print a end. 解:(1) 參數(shù)的傳遞辦法為“傳名”時(shí),a 為 9。(2) 參數(shù)的傳遞辦法為“傳地址”,a 為 8。(3) 參數(shù)的傳遞辦法為“得結(jié)果”,a 為 7。(4) 參數(shù)的傳遞辦法為“傳值”,a 為 2。 例2:過(guò)程參數(shù)的傳遞方式有幾種?簡(jiǎn)述“傳地址”和“傳值”的實(shí)現(xiàn)原理。解:參數(shù)的傳遞方式有下述幾種:傳值,傳地址,傳名,得結(jié)果“傳值”方式,這是最簡(jiǎn)單的參數(shù)

19、傳遞方法。即將實(shí)參計(jì)算出它的值,然后把它傳給被調(diào)過(guò)程。具體來(lái)講是這樣的:1.形式參數(shù)當(dāng)作過(guò)程的局部變量處理,即在被調(diào)過(guò)程的活動(dòng)記錄中開(kāi)辟了形參的存儲(chǔ)空間,這些存儲(chǔ)位置即是我們所說(shuō)的實(shí)參或形式單元。2.調(diào)用過(guò)程計(jì)算實(shí)參的值,并將它們的右值(r-value)放在為形式單元開(kāi)辟的空間中。3.被調(diào)用過(guò)程執(zhí)行時(shí),就像使用局部變量一樣使用這些形式單元?!皞鞯刂贰狈绞?,也稱作傳地址,或引用調(diào)用。調(diào)用過(guò)程傳給被調(diào)過(guò)程的是指針,指向?qū)崊⒋鎯?chǔ)位置的指針。1.如實(shí)參是一個(gè)名字或是具有左值的表達(dá)式,則左值本身傳遞過(guò)去。2.如實(shí)參是一個(gè)表達(dá)式,比方a+b或2,而沒(méi)有左值,則表達(dá)式先求值,并存入某一位置,然后該位置的地址

20、傳遞過(guò)去。3.被調(diào)過(guò)程中對(duì)形式參數(shù)的任何引用和賦值都通過(guò)傳遞到被調(diào)過(guò)程的指針被處理成間接訪問(wèn)。例3:下面是一個(gè)Pascal程序program PP(input,output)var K:integer;function F(N:integer):integerbeginif N< =0 then F:=1else F:=N * F(N-1);end;begin K:=F(10);.end;當(dāng)?shù)诙危ㄟf歸地)進(jìn)入F后,DISPLAY的內(nèi)容是什么?當(dāng)時(shí)整個(gè)運(yùn)行棧的內(nèi)容是什么?解:第十章例1:何謂代碼優(yōu)化?進(jìn)行優(yōu)化所需要的基礎(chǔ)是什么?解:對(duì)代碼進(jìn)行等價(jià)變換,使得變換后的代碼運(yùn)行結(jié)果與變換前代碼

21、運(yùn)行結(jié)果相同,而運(yùn)行速度加快或占用存儲(chǔ)空間減少,或兩者都有。優(yōu)化所需要的基礎(chǔ)是在中間代碼生成之后或目標(biāo)代碼生成之后。例2:編譯過(guò)程中可進(jìn)行的優(yōu)化如何分類(lèi)?最常用的代碼優(yōu)化技術(shù)有哪些?解:依據(jù)優(yōu)化所涉及的程序范圍,可以分為:局部?jī)?yōu)化、循環(huán)優(yōu)化和全局優(yōu)化。最常用的代碼優(yōu)化技術(shù)有1. 刪除多余運(yùn)算2. 代碼外提3. 強(qiáng)度削弱4. 變換循環(huán)控制條件5. 合并已知量與復(fù)寫(xiě)傳播6. 刪除無(wú)用賦值例3:試對(duì)以下基本塊B2:B:=3 D:=A+CE:=A*C F:=D+EG:=B*F H:=A+CI:=A*C J:=H+IK:=B*5 L:=K+JM:=L應(yīng)用DAG 對(duì)它們進(jìn)行優(yōu)化,并就以下兩種情況分別寫(xiě)出優(yōu)

22、化后的四元式序列:(1)假設(shè)只有G、L、M 在基本塊后面還要被引用。(2)假設(shè)只有L 在基本塊后面還要被引用。解:基本塊對(duì)應(yīng)的DAG 如下:B:=3 D:=A+CE:=A*C F:=D+EG:=B*F H:=A+CI:=A*C J:=H+IK:=B*5 L:=K+JM:=L例1 一個(gè)編譯程序的代碼生成要著重考慮哪些問(wèn)題?解:代碼生成器的設(shè)計(jì)要著重考慮目標(biāo)代碼的質(zhì)量問(wèn)題,而衡量目標(biāo)代碼的質(zhì)量主要從占用空間和執(zhí)行效率兩個(gè)方面綜合考慮。課后習(xí)題答案:P36-6(1)是09組成的數(shù)字串(2)最左推導(dǎo):最右推導(dǎo):P36-8文法:最左推導(dǎo):最右推導(dǎo):語(yǔ)法樹(shù):/*P36-9句子iiiei有兩個(gè)語(yǔ)法樹(shù):P64

23、7(1)XY X1234Y5 0 1 1 0 1 1確定化:01X1,2,31,2,32,32,3,42,32,32,3,42,3,42,3,52,3,42,3,52,32,3,4,Y2,3,4,Y2,3,52,3,4 0320 1 01 0 0 1 1 0654 0 1 0 1 1 1最小化: 002 1 1 0 0 1 0543 0 1 0 1 1 1P6412(a) a10 a,b a確定化:ab00,110,10,1110給狀態(tài)編號(hào):ab012112203333 a10 a a b b b32 b a最小化: a a210 b b a b(b)032 b b a a b a a b54

24、1 b a a a已經(jīng)確定化了,進(jìn)行最小化最小化:021 b b a a b aP811(1) 按照T,S的順序消除左遞歸遞歸子程序:procedure S;beginif sym='a' or sym='' then abvanceelse if sym='(' then beginadvance;T;if sym=')' then advance;else error; endelse errorend;procedure T;beginS;end;procedure ;beginif sym=',' then

25、 beginadvance;S;endend;其中:sym:是輸入串指針I(yè)P所指的符號(hào) advance:是把IP調(diào)至下一個(gè)輸入符號(hào)error:是出錯(cuò)診察程序(2)FIRST(S)=a,(FIRST(T)=a,(FIRST()=,FOLLOW(S)=),#FOLLOW(T)=)FOLLOW()=)預(yù)測(cè)分析表a(),#ST是LL(1)文法P812文法:(1)FIRST(E)=(,a,b,FIRST(E')=+,FIRST(T)=(,a,b,FIRST(T')=(,a,b,FIRST(F)=(,a,b,FIRST(F')=*,FIRST(P)=(,a,b,FOLLOW(E)=

26、#,)FOLLOW(E')=#,)FOLLOW(T)=+,),#FOLLOW(T')=+,),#FOLLOW(F)=(,a,b,+,),#FOLLOW(F')=(,a,b,+,),#FOLLOW(P)=*,(,a,b,+,),#(2)考慮下列產(chǎn)生式:FIRST(+E)FIRST()=+=FIRST(+E)FOLLOW(E')=+#,)=FIRST(T)FIRST()=(,a,b,=FIRST(T)FOLLOW(T')=(,a,b,+,),#=FIRST(*F')FIRST()=*=FIRST(*F')FOLLOW(F')=*(,a

27、,b,+,),#=FIRST(E)FIRST(a) FIRST(b) FIRST()=所以,該文法式LL(1)文法.(3)+*()ab#EE'TT'FF'P(4)procedure E;beginif sym='(' or sym='a' or sym='b' or sym='' then begin T; E' end else errorendprocedure E'beginif sym='+' then begin advance; E end else if sym

28、<>')' and sym<>'#' then errorendprocedure T;beginif sym='(' or sym='a' or sym='b' or sym='' then begin F; T' end else errorendprocedure T'beginif sym='(' or sym='a' or sym='b' or sym='' then T else if

29、 sym='*' then errorendprocedure F;beginif sym='(' or sym='a' or sym='b' or sym='' then begin P; F' end else errorendprocedure F'beginif sym='*' then begin advance; F' endendprocedure P;beginif sym='a' or sym='b' or sym='

30、' then advance else if sym='(' thenbeginadvance; E;if sym=')' then advance else errorendelse errorend;P1331短語(yǔ): E+T*F, T*F,直接短語(yǔ): T*F句柄: T*FP1332文法:(1)最左推導(dǎo):最右推導(dǎo):(2)(a,a),(a),a)(S,a),(a),a)(T,a),(a),a)(T,S),(a),a)(T),(a),a)(S,(a),a)(T,(a),a)(T,S,(a),a)(T,(a),a)(T,(S),a)(T,(T),a)(T,S

31、),a)(T),a)(S,a)(T,S)(T)S“移進(jìn)-歸約”過(guò)程:步驟棧輸入串動(dòng)作0#(a,a),(a),a)# 預(yù)備1#(a,a),(a),a)# 進(jìn)2#(a,a),(a),a)#進(jìn)3#(a,a),(a),a)#進(jìn)4#(a,a),(a),a)#進(jìn)5#(S,a),(a),a)#歸6#(T,a),(a),a)#歸7#(T,a),(a),a)#進(jìn)8#(T,a),(a),a)#進(jìn)9#(T,S),(a),a)#歸10#(T),(a),a)#歸11#(T),(a),a)#進(jìn)12#(S,(a),a)#歸13#(T,(a),a)#歸14#(T,(a),a)#進(jìn)15#(T,(a),a)#進(jìn)16#(T,S,(

32、a),a)#歸17#(T,(a),a)#歸18#(T,(a),a)#進(jìn)19#(T,(a),a)#進(jìn)20#(T,(a),a)#進(jìn)21#(T,(S),a)#歸22#(T,(T),a)#歸23#(T,(T),a)#進(jìn)24#(T,S),a)#歸25#(T),a)#歸26#(T),a)#進(jìn)27#(S,a)#歸28#(T,a)#歸29#(T,a)#進(jìn)30#(T,a)#進(jìn)31#(T,S)#歸32#(T)#歸33#(T)#進(jìn)34#S#歸P1333(1) FIRSTVT(S)=a,(FIRSTVT(T)=,a,(LASTVT(S)=a,)LASTVT(T)=,a,)(2)a(),a>>>>

33、;(<<<=<)>>,<<<>>是算符文法,并且是算符優(yōu)先文法(3)優(yōu)先函數(shù)a(),f44244g55523 (4) 棧輸入字符串動(dòng)作#(a,(a,a))#預(yù)備#(a, (a,a)#進(jìn)#(a, (a,a)#進(jìn)#(s, (a,a)#歸#(t, (a,a)#歸#(t,(a,a))#進(jìn)#(t,(a,a)#進(jìn)#(t,(a,a)#進(jìn)#(t,(s,a)#歸#(t,(t,a)#歸#(t,(t,a)#進(jìn)#(t,(t,a)#進(jìn)#(t,(t,s)#歸#(t,(t)#歸#(t,(t)#進(jìn)#(t,s)#歸#(t)#歸#(t)#進(jìn)# s#歸P1641 答

34、:表達(dá)式(4*7+1)*2的附注語(yǔ)法樹(shù)如下圖:digit.lexval=2F.val=2E.val=58ndigit.lexval=4digit.lexval=7digit.lexval=1F.val=4F.val=7F.val=1T.val=4*T.val=28E.val=28+T.val=1E.val=1E.val=29()F.val=29T.val=29T.val=58*LP1642答:(1)ab+(2)ab+P16511答:(1)Did LD.type:= L.type;addtype(id.type,L.type)L, id L1L.type:= L1.type;addtype(id

35、.type,L1.type)L : TL.type:= T.typeTinteger T.type := integerT real T.type := realP2171a*(-b+c)abc+*a+b*(c+d/e)abcde/+*+-a+b*(-c+d)abcd+*+A (C or not D)A not C Dnot or not or(A and B) or (not C or D)A B and C not D or or (A or B) and (C or not D and E)A B or C D not E and or and if (x+y)*z =0 then (a+b)c else abcxy+z*0= ab+cabc ¥或 xy+z*0= P1 jez ab+c P2 jump abc P1 P2P2173-(a+b)*(c+d)-(a+b+c)的三元式序列:(1) +, a, b(2) , (1), -(3) +, c, d(4) *, (2), (3)(5) +

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論