編譯原理_第三版_課后答案_第1頁
編譯原理_第三版_課后答案_第2頁
編譯原理_第三版_課后答案_第3頁
編譯原理_第三版_課后答案_第4頁
編譯原理_第三版_課后答案_第5頁
已閱讀5頁,還剩22頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、.;編譯 原理 課后題答案第二章P36-6(1)是09組成的數(shù)字串(2)最左推導:最右推導:P36-7G(S)P36-8文法:最左推導:最右推導:語法樹:/*/P36-9句子iiiei有兩個語法樹:P36-10/*/P36-11/*L1:L2:L3:L4:*/第三章習題參考答案P647(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

2、0 0 1 0543 0 1 0 1 1 1P648(1) (2)(3)P6412(a) a10 a,b a確定化:ab00,110,10,1110給狀態(tài)編號:ab012112203333 a10 a a b b b32 b a最小化: a a210 b b a b(b)032 b b a a b a a b541 b a a a已經(jīng)確定化了,進行最小化最小化:021 b b a a b aP6414 (1) 010 1 0(2):YX 2 0 1Y1X 0確定化:01X,1,Y1,Y21,Y1,Y221,Y給狀態(tài)編號:01012112213333 010 0 1 032 1 1 1 0最小化

3、: 0310 1 1 1 0 0第四章P811(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 beginadvance;S;endend;其中:sym:是輸入串指針I(yè)P所指的符號 advance:是把IP調至下一個輸入符號error:

4、是出錯診察程序(2)FIRST(S)=a,(FIRST(T)=a,(FIRST()=,FOLLOW(S)=),#FOLLOW(T)=)FOLLOW()=)預測分析表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)=#,)FOLLOW(E)=#,)FOLLOW(T)=+,),#FOLLOW(T)=+,),#FOLLOW(F)=(,a,b,+,),#FOLLOW(F)=(,a,b,+,)

5、,#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,b,+,),#=FIRST(E)FIRST(a) FIRST(b) FIRST()=所以,該文法式LL(1)文法.(3)+*()ab#EETTFFP(4)procedure E;beginif sym=( or sym=a or sym=b or s

6、ym= then begin T; E end else errorendprocedure E;beginif sym=+ then begin advance; E end else if sym) 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 sym=* then errorendproce

7、dure 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= then advance else if sym=( thenbeginadvance; E;if sym=) then advance else errorendelse errorend;P813/*(1) 是,滿足三個條件。(2) 不是,對

8、于A不滿足條件3。(3) 不是,A、B均不滿足條件3。(4) 是,滿足三個條件。*/第五章P1331短語: E+T*F, T*F,直接短語: T*F句柄: T*FP1332文法:(1)最左推導:最右推導:(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),a)(T),a)(S,a)(T,S)(T)S“移進-歸約”過程:步驟棧輸入串動作0#(a,a),(a),a)#預備1#(a,a),(a),a)#進2#

9、(a,a),(a),a)#進3#(a,a),(a),a)#進4#(a,a),(a),a)#進5#(S,a),(a),a)#歸6#(T,a),(a),a)#歸 7#(T,a),(a),a)#進8#(T,a),(a),a)#進9#(T,S),(a),a)#歸10#(T),(a),a)#歸11#(T),(a),a)#進12#(S,(a),a)#歸13#(T,(a),a)#歸 14#(T,(a),a)#進15#(T,(a),a)#進16#(T,S,(a),a)#歸17#(T,(a),a)#歸18#(T,(a),a)#進19#(T,(a),a)#進20#(T,(a),a)#進21#(T,(S),a)#歸

10、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#歸P1333(1) FIRSTVT(S)=a,(FIRSTVT(T)=,a,(LASTVT(S)=a,)LASTVT(T)=,a,)(2)a(),a(=,是算符文法,并且是算符優(yōu)先文法(3)優(yōu)先函數(shù)a(),f44244g55523 (4) 棧輸入字符串動作#(a,(a,a))#預備#(a, (a,a)#進#(a, (a,a)#進#

11、(t, (a,a)#歸#(t,(a,a))#進#(t,(a,a)#進#(t,(a,a)#進#(t,(t,a)#歸#(t,(t,a)#進#(t,(t,a)#進#(t,(t,s)#歸#(t,(t)#歸#(t,(t)#進#(t,s)#歸#(t)#歸#(t)#進# s#歸successP1345(1)..1.(2)1987 S A S 11100 a 432 A S d 56確定化:SAab0,2,5,7,101,2,5,7,8,102,3,5,7,101161,2,5,7,8,102,5,7,8,102,3,5,7,9,101162,3,5,7,102,4

12、,5,7,8,102,3,5,7,101162,5,7,8,102,5,7,8,102,3,5,7,9,101162,3,5,7,9,102,4,5,7,8,102,3,5,7,101162,4,5,7,8,102,5,7,8,102,3,5,7,9,10116116 A S3:5:6: S A a b S a A S b S A b a A4:0:7: A S b a a b b a2:1: DFA構造LR(0)項目集規(guī)范族也可以用GO函數(shù)來計算得到。所得到的項目集規(guī)范族與上圖中的項目集一樣:=,GO(,a)= =GO(,b)= =GO(,S)= ,=GO(,A)= ,=GO(,a)= =G

13、O(,b)= =GO(,S)= ,=GO(,A)= ,=GO(,a)= =GO(,b)= =GO(,S)= ,=GO(,A)= ,=GO(,a)= =GO(,b)= =GO(,S)= ,=GO(,A)= ,=GO(,a)= =GO(,b)= =GO(,S)= ,=GO(,A)= ,=GO(,a)= =GO(,b)= =GO(,S)= ,=GO(,A)= ,=項目集規(guī)范族為C=,(3)不是SLR文法狀態(tài)3,6,7有移進歸約沖突狀態(tài)3:FOLLOW(S)=#不包含a,b狀態(tài)6:FOLLOW(S)=#,a,b包含a,b,;移進歸約沖突無法消解狀態(tài)7:FOLLOW(A)=a,b包含a,b;移進歸約沖突

14、消解所以不是SLR文法。(4) 構造例如LR(1)項目集規(guī)范族見下圖:對于狀態(tài)5,因為包含項目,所以遇到搜索符號a或b時,應該用歸約。又因為狀態(tài)5包含項目,所以遇到搜索符號a時,應該移進。因此存在“移進-歸約”矛盾,所以這個文法不是LR(1)文法。 b b b8:1:5: A A A S a a S3: S a S3:0: a a A a A6:9: 4: S b S A b a a S b b7:2:10: S b A A5:第六章/*第六章會有點難P1645(1)EE1T if (E1.type = int) and (T.type = int )then E.type := intels

15、e E.type := realETE.type := T.typeTnum.num T.type := realTnumT.type := int(2)P1647SL1|L2S.val:=L1.val+(L2.val/2)SLS.val:=L.valLL1BL.val:=2*L1.val + B.val; L.length:=L1.length+1LBL.val:=B.c; L.length :=1B0 B.c:=0B1B.c:=1*/第七章P2171a*(-b+c)abc+*a+b*(c+d/e)abcde/+*+-a+b*(-c+d)abcd+*+if (x+y)*z =0 then (

16、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) +, a, b(6) +, (5), c(7) -, (4), (6)間接三元式序列:三元式表:(1) +, a, b(2) , (1), -(3) +, c, d(4) *, (2), (3)(5) +, (1), c(6) -, (4), (5)間接碼表:(1)(2)(3)(4)(1)

17、(5)(6)四元式序列:(1) +, a, b, (2) , , -, (3) +, c, d, (4) *, , , (5) +, a, b, (6) +, , c, (7) -, , , P2184自下而上分析過程中把賦值句翻譯成四元式的步驟:A:=B*(-C+D)步驟輸入串棧 PLACE四元式(1)A:=B*(-C+D)(2):=B*(-C+D)i A(3)B*(-C+D)i:= A-(4)*(-C+D)i:=iA-B(5)*(-C+D)i:=EA-B(6)*(-C+D)i:=EA-B(7)(-C+D)i:=E*A-B-(8)-C+D)i:=E*(A-B-(9)C+D)i:=E*(-A-

18、B-(10)+D) i:=E*(-iA-B-C(11)+D) i:=E*(-EA-B-C(,C,-, )(12)+D) i:=E*(EA-B-(13)D) i:=E*(E+A-B-(14) i:=E*(E+iA-B-D(15)i:=E*(E+EA-B-D(+,D,)(16)i:=E(EA-B-(17)i:=E*(E)A-B-(18)i:=E+EA-B-(*,B,)(19)i:=EA-(:=,-,A)(20) A產(chǎn)生的四元式:(,C,-, )(+,D,)(*,B,)(:=,-,A)P2185/*設A :10*20,B、C、D:20,寬度為w4 則T1:= i * 20T1:=T1+jT2:=A8

19、4T3:=4*T1Tn:=T2T3 /這一步是多余的T4:= i + jT5:=B4T6:=4*T4T7:=T5T6T8:= i * 20T8:=T8+jT9:=A84T10:=4*T8T11:=T9T10T12:= i + jT13:=D4T14:=4*T12T15:= T13T14T16:=T11+T15T17:=C4T18:=4*T16T19:=T17T18T20:=T7+T19Tn:=T20*/P2186100. (jnz, A, -, 0)101. (j, -, -, 102)102. (jnz, B, -, 104)103. (j, -, -, 0)104. (jnz, C, -,

20、 103)105. (j, -, -, 106)106. (jnz, D, -, 104) -假鏈鏈首107. (j, -, -, 100) -真鏈鏈首假鏈:106,104,103真鏈:107,100P2187100. (j, A, C, 102)101. (j, -, -, 0)102. (j,E1.place ,E2.place ,0);emit(I.Place :=E1.place);F.truelist := makelist(nextquad);emit(j,-,-,-);F.place := I.place;F.end := E2.place;p:=lookup();

21、 if p nil thenI.place := pelse error M.quad := nextquad*/方法2:S for id:=E1 to E2 do S1S F S1F for id:=E1 to E2 do doINITIAL=NEWTEMP;emit(:=,E1.PLACE, -, INITIAL);FINAL=NEWTEMP;emit(:=,E2.PLACE, -, FINAL);p:= nextquad+2;emit(j, INITIAL , FINAL , p);F.nextlist:=makelist(nextquad);emit(j,);F.place:=look

22、up();if F.placenil thenemit(F.place := INITIAL)F.quad:=nextquad;F.final:=FINAL;backpatch(S1.nextlist, nextquad)p:=nextquad+2;emit(j, F.place, F.final , p );S.nextlist := merge(F.nextlist, makelist(nextquad);emit(j,);emit(succ, F.place , -, F.place);emit(j, F.quad);第九章P2709(1) 傳名即當過程調用時,其作用相當于

23、把被調用段的過程體抄到調用出現(xiàn)處,但必須將其中出現(xiàn)的任一形式參數(shù)都代之以相應的實在參數(shù)。A:=2; B:=3; A:=A+1; A:=A+(A+B); print A; A=9 (2) 傳地址即當程序控制轉入被調用段后,被調用段首先把實在參數(shù)抄進相應的形式參數(shù)的形式單元中,過程體對形參的任何引用或賦值都被處理成對形式單元的間接訪問。當被調用段工作完畢返回時,形式單元(都是指示器)所指的實參單元就持有所希望的值。A:=2;B:=3;T:=A+B把T,A,A的地址抄進已知單元J1,J2,J3x:J1;y:=J2;z:=J3 /把實參地址抄進形式單元,且J2=J3Y:=y+1 Z:=z+x / Y:對y的間接訪問 Z:對z的間接訪問print AA=8(3) 得結果每個形參均對應兩個單元,第一個存放實參地址,第二個存放實參值,在過程體中對形參的任何引用或賦值都看成是對它的第二個單元的直接訪問,但在過程工作完畢返回前必須把第二個單元的內(nèi)容放到第一個單元所指的那個實參單元中A:=2;B:=3;T:

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論