考虑文法
S → ( L ) ∣ a L → L , S ∣ S S \rightarrow (L)\space | \space a\\ L\rightarrow L, S \space | \space S S→(L) ∣ aL→L,S ∣ S
(a) 建立句子 ( a , ( a , a ) ) (a,(a,a)) (a,(a,a)) 和 ( a , ( a , a ) , ( a , a ) ) (a,(a,a),(a,a)) (a,(a,a),(a,a)) 的分析树。
见下面两题。
(b) 为 (a) 的两个句子构造最左推导。
( a , ( a , a ) ) (a,(a,a)) (a,(a,a)) 最左推导的分析树(包括推导过程中的分析树):
( a , ( a , a ) , ( a , a ) ) (a,(a,a),(a,a)) (a,(a,a),(a,a)) 最左推导的分析树:
S ⇒ l m ( L ) ⇒ l m ( L , S ) ⇒ l m ( S , S ) ⇒ l m ( a , S ) ⇒ l m ( a , ( L ) ) ⇒ l m ( a , ( L , S ) ) ⇒ l m ( a , ( S , S ) ) ⇒ l m ( a , ( ( L ) , S ) ) ⇒ l m ( a , ( ( L , S ) , S ) ) ⇒ l m ( a , ( ( S , S ) , S ) ) ⇒ l m ( a , ( ( a , S ) , S ) ) ⇒ l m ( a , ( ( a , a ) , S ) ) ⇒ l m ( a , ( ( a , a ) , ( L ) ) ) ⇒ l m ( a , ( ( a , a ) , ( L ) ) ) ⇒ l m ( a , ( ( a , a ) , ( L , S ) ) ) ⇒ l m ( a , ( ( a , a ) , ( S , S ) ) ) ⇒ l m ( a , ( ( a , a ) , ( a , S ) ) ) ⇒ l m ( a , ( ( a , a ) , ( a , a ) ) ) S\Rightarrow_{lm} (L)\Rightarrow_{lm} (L,S) \Rightarrow_{lm} (S,S) \Rightarrow_{lm} (a,S) \Rightarrow_{lm}(a,(L)) \Rightarrow_{lm} (a,(L,S)) \Rightarrow_{lm} (a,(S,S)) \Rightarrow_{lm} (a,((L),S))\\ \Rightarrow_{lm} (a,((L,S),S)) \Rightarrow_{lm} (a,((S,S),S))\Rightarrow_{lm} (a,((a,S),S)) \Rightarrow_{lm} (a,((a,a),S)) \Rightarrow_{lm} (a,((a,a),(L)))\\ \Rightarrow_{lm} (a,((a,a),(L))) \Rightarrow_{lm} (a,((a,a),(L,S)))\Rightarrow_{lm} (a,((a,a),(S,S))) \Rightarrow_{lm} (a,((a,a),(a,S))) \Rightarrow_{lm} (a,((a,a),(a,a))) S⇒lm(L)⇒lm(L,S)⇒lm(S,S)⇒lm(a,S)⇒lm(a,(L))⇒lm(a,(L,S))⇒lm(a,(S,S))⇒lm(a,((L),S))⇒lm(a,((L,S),S))⇒lm(a,((S,S),S))⇒lm(a,((a,S),S))⇒lm(a,((a,a),S))⇒lm(a,((a,a),(L)))⇒lm(a,((a,a),(L)))⇒lm(a,((a,a),(L,S)))⇒lm(a,((a,a),(S,S)))⇒lm(a,((a,a),(a,S)))⇒lm(a,((a,a),(a,a)))
(c) 为 (a) 的两个句子构造最右推导。
( a , ( a , a ) ) (a,(a,a)) (a,(a,a)) 最右推导的分析树(包括推导过程中的分析树):
( a , ( a , a ) , ( a , a ) ) (a,(a,a),(a,a)) (a,(a,a),(a,a)) 最右推导:
S ⇒ r m ( L ) ⇒ r m ( L , S ) ⇒ r m ( L , ( L ) ) ⇒ r m ( L , ( L , S ) ) ⇒ r m ( L , ( L , ( L ) ) ) ⇒ r m ( L , ( L , ( L , S ) ) ) ⇒ r m ( L , ( L , ( L , a ) ) ) ⇒ r m ( L , ( L , ( S , a ) ) ) ⇒ r m ( L , ( L , ( a , a ) ) ) ⇒ r m ( L , ( S , ( a , a ) ) ) ⇒ r m ( L , ( ( L ) , ( a , a ) ) ) ⇒ r m ( L , ( ( L , S ) , ( a , a ) ) ) ⇒ r m ( L , ( ( L , a ) , ( a , a ) ) ) ⇒ r m ( L , ( ( S , a ) , ( a , a ) ) ) ⇒ r m ( L , ( ( a , a ) , ( a , a ) ) ) ⇒ r m ( S , ( ( a , a ) , ( a , a ) ) ) ⇒ r m ( a , ( ( a , a ) , ( a , a ) ) ) S\Rightarrow_{rm} (L) \Rightarrow_{rm} (L,S) \Rightarrow_{rm} (L,(L)) \Rightarrow_{rm} (L,(L,S)) \Rightarrow_{rm} (L,(L,(L)))\Rightarrow_{rm} (L,(L,(L,S)))\Rightarrow_{rm} (L,(L,(L,a))) \\ \Rightarrow_{rm} (L,(L,(S,a))) \Rightarrow_{rm} (L,(L,(a,a))) \Rightarrow_{rm} (L,(S,(a,a))) \Rightarrow_{rm} (L,((L),(a,a)))\Rightarrow_{rm} (L,((L,S),(a,a))) \\ \Rightarrow_{rm} (L,((L,a),(a,a))) \Rightarrow_{rm} (L,((S,a),(a,a)))\Rightarrow_{rm} (L,((a,a),(a,a))) \Rightarrow_{rm} (S,((a,a),(a,a)))\Rightarrow_{rm} (a,((a,a),(a,a))) S⇒rm(L)⇒rm(L,S)⇒rm(L,(L))⇒rm(L,(L,S))⇒rm(L,(L,(L)))⇒rm(L,(L,(L,S)))⇒rm(L,(L,(L,a)))⇒rm(L,(L,(S,a)))⇒rm(L,(L,(a,a)))⇒rm(L,(S,(a,a)))⇒rm(L,((L),(a,a)))⇒rm(L,((L,S),(a,a)))⇒rm(L,((L,a),(a,a)))⇒rm(L,((S,a),(a,a)))⇒rm(L,((a,a),(a,a)))⇒rm(S,((a,a),(a,a)))⇒rm(a,((a,a),(a,a)))
(d) 这个文法产生的语言是什么?
该文法产生的语言是括号匹配的串,串中的各项用“,”隔开,项可以是括号匹配的子串或 a。
考虑文法
S → a S b S ∣ b S a S ∣ ε S\rightarrow aSbS\space|\space bSaS \space | \space \varepsilon S→aSbS ∣ bSaS ∣ ε
(a) 为句子 a b a b abab abab 构造两个不同的最左推导,以此说明该文法是二义的。
第一种最左推导的分析树(包括推导过程中的分析树):
第二种最左推导的分析树(包括推导过程中的分析树):
一个文法,如果存在某个句子有不止一棵分析树与之对应,那么称这个文法是二义的;故,该文法是是二义的。
(b) 为 a b a b abab abab 构造对应的最右推导。
两种最右推导的分析树(包括推导过程中的分析树)如下:
(c) 为 a b a b abab abab 构造对应的分析树。
见上面四幅图。
(d) 这个文法产生的语言是什么?
通过最左推导的方式和产生式 S → a S b S\rightarrow aSb S→aSb 可以得到前缀为若干个 a a a 的任意长度的串;
通过最左推导的方式和产生式 S → b S a S\rightarrow bSa S→bSa 可以得到前缀为若干个 b b b 的任意长度的串;
题目给的产生式为 S → a S b S S\rightarrow aSbS S→aSbS 、 S → b S a S S\rightarrow bSaS S→bSaS 和 S → ε S\rightarrow \varepsilon S→ε,由 S S S 可以推导出空串,可以说明可以产生 S → a S b S\rightarrow aSb S→aSb 和 S → b S a S\rightarrow bSa S→bSa,因此由任意长度的前缀 a a a 和前缀 b b b 的子串可以构成 a a a 和 b b b 任意交错的串;
又因为每个产生式中 a a a 和 b b b 的个数都相同,故产生 a a a 和 b b b 数目相等且任意长度的串。
下面的二义文法描述命题演算公式,为它写一个等价的非二义性文法。
S → S and S ∣ S or S ∣ not S ∣ true ∣ false ∣ ( S ) S→S \space\textbf{and}\space S\space|\space S\space \textbf{or}\space S\space|\space \textbf{not}\space S\space|\space \textbf{true}\space|\space \textbf{false} \space|\space(S) S→S and S ∣ S or S ∣ not S ∣ true ∣ false ∣ (S)
通过引入非终结符消除二义性:
E → E or T ∣ T T → T and F ∣ F F → not F ∣ ( E ) ∣ true ∣ false E\rightarrow E \textbf{or}\space T\space |\space T \\ T\rightarrow T \textbf{and}\space F\space |\space F \\ F\rightarrow \textbf{not} \space F\space |\space (E)\space |\space \textbf{true}\space |\space \textbf{false} \\ E→Eor T ∣ TT→Tand F ∣ FF→not F ∣ (E) ∣ true ∣ false
文法
R → R ′ ∣ ′ R ∣ R R ∣ R ∗ ∣ ( R ) ∣ a ∣ b R\rightarrow R\space '|' \space R \space |\space R \space R \space|\space R^*\space|\space(R)\space|\space a \space | \space b R→R ′∣′ R ∣ R R ∣ R∗ ∣ (R) ∣ a ∣ b
产生字母表 { a , b } \{a,b\} {a,b} 上所有不含 ε \varepsilon ε 的正规式。注意,第一条竖线加了引号,它是正规式的或运算符号,而不是文法产生式右部各选择之间的分隔符,另外 ∗ ^* ∗在这里是一个普通的终结符。该文法是二义的。
(a) 证明该文法产生字母表 { a , b } \{a,b\} {a,b} 上的所有正规式。
证明:
(1) 该文法产生的串是字母表 { a , b } \{a,b\} {a,b} 上的正规式:
R → a R\rightarrow a R→a和 R → b R\rightarrow b R→b产生 a a a和 b b b,而 a a a和 b b b是 { a , b } \{a,b\} {a,b}上的符号,因此是正规式。若 R 1 R_1 R1, R 2 R_2 R2产生正规式 α \alpha α和 β \beta β
则:
R → R 1 R 2 R\rightarrow R_1R_2 R→R1R2 产生正规式 α β \alpha\beta αβ
R → R 1 ∣ R 2 R\rightarrow R_1|R_2 R→R1∣R2 产生正规式 α ∣ β \alpha\space|\space\beta α ∣ β
R → R 1 ∗ R\rightarrow R_1^* R→R1∗ 产生正规式 α ∗ \alpha^* α∗
R → ( R 1 ) R\rightarrow (R_1) R→(R1) 产生正规式 ( α ) (\alpha) (α)
(2) 字母表 { a , b } \{a,b\} {a,b} 上的所有正规式都可由此文法产生:
字母表 { a , b } \{a,b\} {a,b} 上的任一正规式(其中 α \alpha α, β \beta β 为正规式)必为以下形式之一:
α β \alpha\beta αβ,可由 R → R R R\rightarrow RR R→RR 产生
α ∣ β \alpha\space | \space\beta α ∣ β,可由 R → R ∣ R R\rightarrow R\space | \space R R→R ∣ R 产生
α ∗ \alpha^* α∗,可由 R → R ∗ R\rightarrow R^* R→R∗ 产生
( α ) (\alpha) (α),可由 R → ( R ) R\rightarrow (R) R→(R) 产生
a a a,可由 R → a R\rightarrow a R→a 产生
b b b,可由 R → b R\rightarrow b R→b 产生
因而,该文法产生字母表 { a , b } \{a,b\} {a,b} 上的所有正规式
(b) 为该文法写一个等价的非二义文法。它给予算符 ∗ ^* ∗ 、连接和 ∣ | ∣ 的优先级和结合性同 2.2 节中定义的一致。
该文法没有体现运算符 ∗ ^* ∗ 、 ( ) () ()、 ∣ | ∣ 和连接的优先级,因而是二义的。例如:
R ⇒ R ∣ R ⇒ a ∣ R ⇒ a ∣ R ∗ ⇒ a ∣ b ∗ R ⇒ R ∗ ⇒ R ∣ R ∗ ⇒ a ∣ R ∗ ⇒ a ∣ b ∗ R\Rightarrow R\space | \space R \Rightarrow a\space | \space R\space\Rightarrow a\space|\space R^*\Rightarrow a\space|\space b^* \\ R\Rightarrow R^* \Rightarrow R\space | \space R^*\space\Rightarrow a\space|\space R^*\Rightarrow a\space|\space b^* R⇒R ∣ R⇒a ∣ R ⇒a ∣ R∗⇒a ∣ b∗R⇒R∗⇒R ∣ R∗ ⇒a ∣ R∗⇒a ∣ b∗
通过引入非终结符消除二义性:
E → E ′ ∣ ′ T ∣ T T → T F ∣ F F → F ∗ ∣ ( E ) ∣ a ∣ b E\rightarrow E\space'|' \space T \space|\space T \\ T\rightarrow TF\space |\space F \\ F\rightarrow F^*\space | \space (E)\space |\space a \space |\space b E→E ′∣′ T ∣ TT→TF ∣ FF→F∗ ∣ (E) ∣ a ∣ b
消除二义性后:
E ⇒ E ∣ T ⇒ E ∣ F ⇒ E ∣ F ∗ ⇒ E ∣ b ∗ ⇒ T ∣ b ∗ ⇒ F ∣ b ∗ ⇒ a ∣ b ∗ E\Rightarrow E\space|\space T\Rightarrow E\space|\space F\Rightarrow E\space|\space F^*\space\Rightarrow E\space |\space b^* \Rightarrow T\space | \space b^* \Rightarrow F \space | \space b^*\Rightarrow a \space | \space b^* E⇒E ∣ T⇒E ∣ F⇒E ∣ F∗ ⇒E ∣ b∗⇒T ∣ b∗⇒F ∣ b∗⇒a ∣ b∗
(c) 按上面两个文法构造句子 a b ∣ b ∗ a ab\space|\space b^*a ab ∣ b∗a 的分析树。
存在二义性:
不存在二义性:
条件语句文法
s t m t → if e x p r then s t m t ∣ m a t c h e d _ s t m t m a t c h e d _ s t m t → if e x p r then m a t c h e d _ s t m t else s t m s t ∣ other stmt \rightarrow \textbf{if}\space expr \space \textbf{then} \space stmt \space | \space matched\_stmt \\ matched\_stmt \rightarrow \textbf{if} \space expr \space \textbf{then} \space matched\_stmt\space \textbf{else} \space stmst \space | \space \textbf{other} stmt→if expr then stmt ∣ matched_stmtmatched_stmt→if expr then matched_stmt else stmst ∣ other
试图消除悬空 e l s e else else 的二义性,请证明该文法仍然是二义的。
由于 m a t c h e d _ s t m t matched\_stmt matched_stmt不能保证 t h e n then then和 e l s e else else的配对,因而存在二义性。
句型 i f e x p r t h e n i f e x p r t h e n m a t c h e d _ s t m t e l s e i f e x p r t h e n m a t c h e d _ s t m t e l s e s t m t if\space expr\space then \space if \space expr\space then \space matched\_stmt \space else \space if \space expr\space then \space matched\_stmt \space else \space stmt if expr then if expr then matched_stmt else if expr then matched_stmt else stmt 存在两个不同的最左推导。
期望的是:
if expr then
if expr then
matched_stmt
else
if expr then
matched_stmt
else
stmt
一种和期望不一样的推导:
stmt
=> matched_stmt
=> if expr then matched_stmt else stmt
=> if expr then if expr then matched_stmt else stmt else stmt
=> if expr then if expr then matched_stmt else if expr then stmt else stmt
=> if expr then if expr then matched_stmt else if expr then matched_stmt else stmt
if expr then
if expr then
matched_stmt
else
if expr then
matched_stmt
else
stmt
另一种推导:
stmt
=> if expr then stmt
=> if expr then matched_stmt
=> if expr then if expr then matched_stmt else stmt
=> if expr then if expr then matched_stmt else matched_stmt
=> if expr then if expr then matched_stmt else if expr then matched_stmt else stmt
if expr then
if expr then
matched_stmt
else
if expr then
matched_stmt
else
stmt
(a) 消除习题 3.1 文法的左递归。
S → ( L ) ∣ a L → S L ′ L ′ → , S L ′ ∣ ε S\rightarrow (L)\space | \space a \\ L\rightarrow SL' \\ L'\rightarrow\space ,SL'\space | \space \varepsilon S→(L) ∣ aL→SL′L′→ ,SL′ ∣ ε
(b) 为 (a) 的文法构造预测分析器。
F i r s t ( S ) = { ( , a } F i r s t ( L ) = { ( , a } F i r s t ( L ′ ) = { ′ , ′ , ε } F o l l o w ( S ) = { ) , ′ , ′ , $ } F o l l o w ( L ) = { ) , $ } F o l l o w ( L ′ ) = { ) , $ } First(S) = \{\space(\space,\space a\space\} \\ First(L) = \{\space(\space,\space a\space\} \\ First(L') = \{\space','\space,\space\varepsilon\space\} \\\\ Follow(S) = \{\space)\space,\space','\space,\space\$\space\} \\ Follow(L) = \{\space)\space, \space\$\space\} \\ Follow(L')= \{\space)\space, \space\$\space\} \\ First(S)={ ( , a }First(L)={ ( , a }First(L′)={ ′,′ , ε }Follow(S)={ ) , ′,′ , $ }Follow(L)={ ) , $ }Follow(L′)={ ) , $ }
非终结符 | 输入符号 | ||||
( | ) | a | , | $ | |
S | S→(L) | S→a | |||
L | L→SL' | L→SL' | |||
L' | L'→ε | L→,SL' | L'→ε |
构造下面文法的 LL(1) 分析表。
D → T L T → int ∣ real L → id R R → , id R ∣ ε D\rightarrow TL \\ T\rightarrow \textbf{int} \space | \space \textbf{real} \\ L\rightarrow \textbf{id} \space R \\ R\rightarrow\space ,\textbf{id}\space R \space | \space \varepsilon D→TLT→int ∣ realL→id RR→ ,id R ∣ ε
先确定非终结符的 F i r s t First First 和 F o l l o w Follow Follow 集:
F i r s t ( D ) = F i r s t ( T ) = { int , real } F i r s t ( L ) = { id } F i r s t ( R ) = { ′ , ′ , ε } F o l l o w ( D ) = F o l l o w ( L ) = { $ } F o l l o w ( T ) = { id } F o l l o w ( R ) = { $ } First(D)=First(T) = \{\textbf{int}, \textbf{real}\}\\ First(L)=\{\textbf{id}\} \\ First(R)=\{',', \varepsilon\} \\ \\ Follow(D)=Follow(L)=\{\$\} \\ Follow(T)=\{\textbf{id}\} \\ Follow(R)=\{\$\} First(D)=First(T)={int,real}First(L)={id}First(R)={′,′,ε}Follow(D)=Follow(L)={$}Follow(T)={id}Follow(R)={$}
非终结符 | 输入符号 | ||||
int | real | id | , | $ | |
D | D→TL | D→TL | |||
T | T→int | T→real | |||
L | L→idR | ||||
R | R→,idR | R→ε |
构造下面文法的 LL(1) 分析表。
S → a B S ∣ b A S ∣ ε A → b A A ∣ a B → a B B ∣ b S\rightarrow aBS\space |\space bAS \space | \space \varepsilon \\ A\rightarrow bAA\space | \space a \\ B\rightarrow aBB \space | \space b S→aBS ∣ bAS ∣ εA→bAA ∣ aB→aBB ∣ b
F i r s t ( S ) = { a , b , ε } F i r s t ( A ) = F i r s t ( B ) = { a , b } F o l l o w ( S ) = F o l l o w ( A ) = F o l l o w ( B ) = { $ } First(S) = \{a, b, \varepsilon\}\\ First(A) = First(B) =\{a, b\} \\ \\ Follow(S)=Follow(A)=Follow(B)=\{\$\} First(S)={a,b,ε}First(A)=First(B)={a,b}Follow(S)=Follow(A)=Follow(B)={$}
非终结符 | 输入符号 | ||
a | b | $ | |
S | S→aBS S→ε |
S→bAS S→ε |
S→ε |
A | A→a | A→bAA | |
B | B→aBB | B→b |
下面的文法是否为 LL(1) 文法,说明理由。
S → A B ∣ P Q x A → x y B → b c P → d P ∣ ε Q → a Q ∣ ε S\rightarrow AB\space|\space PQx \\ A\rightarrow xy \\ B\rightarrow bc \\ P\rightarrow dP\space|\space \varepsilon\\ Q\rightarrow aQ\space | \space \varepsilon S→AB ∣ PQxA→xyB→bcP→dP ∣ εQ→aQ ∣ ε
上面文法不是 LL(1) 文法。
LL(1) 文法:对于产生式 A → α ∣ β A\rightarrow \alpha \space | \space \beta A→α ∣ β 满足:
① F I R S T ( α ) ∩ F I R S T ( β ) = ϕ FIRST(\alpha)\space∩ \space FIRST(\beta) = \phi FIRST(α) ∩ FIRST(β)=ϕ
② 若 β ⇒ ∗ ε \beta\Rightarrow ^* \varepsilon β⇒∗ε ,那么 F I R S T ( α ) ∩ F o l l o w ( A ) = ϕ FIRST(\alpha)\space∩ \space Follow(A) = \phi FIRST(α) ∩ Follow(A)=ϕ
而本题中, F I R S T ( A B ) = { x } FIRST(AB) = \{x\} FIRST(AB)={x}, F I R S T ( P Q x ) = { d , a , x } FIRST(PQx) = \{d,a,x\} FIRST(PQx)={d,a,x},不满足条件 ①,故,上面文法不是 LL(1) 文法。
为习题3.3的文法构造SLR分析表
扩展文法:
action | goto | ||||||||
and | or | not | true | false | ( | ) | $ | S | |
0 | s2 | s3 | s4 | s5 | 1 | ||||
1 | s6 | s7 | acc | ||||||
2 | s2 | s3 | s4 | s5 | 8 | ||||
3 | r4 | r4 | r4 | r4 | |||||
4 | r5 | r5 | r5 | r5 | |||||
5 | s2 | s3 | s4 | s5 | 9 | ||||
6 | s2 | s3 | s4 | s5 | 10 | ||||
7 | s2 | s3 | s4 | s5 | 11 | ||||
8 | s6/r3 | s7/r3 | r3 | r3 | |||||
9 | s6 | s7 | r12 | ||||||
10 | s6/r1 | s7/r1 | r1 | r1 | |||||
11 | s6/r2 | s7/r2 | r2 | r2 | |||||
12 | r6 | r6 | r6 | r6 |
(a) 为下面文法构造规范LR(1)分析表,画出像图3.20这样的状态转换图就可以。
S → V = E ∣ E V → * E ∣ id E → V S\rightarrow V\textbf{=}E\space|\space E\\ V\rightarrow \textbf{*}E\space|\space\textbf{id}\\ E\rightarrow V S→V=E ∣ EV→*E ∣ idE→V
详述构建 I 0 I_0 I0的过程:
① 拓展文法:
S ′ → S ( 0 ) S → V = E ( 1 ) S → E ( 2 ) V → * E ( 3 ) V → id ( 4 ) E → V ( 5 ) S'\rightarrow S\space\space\space\space (0)\\ S\rightarrow V\textbf{=}E\space\space\space\space (1) \\ S\rightarrow E\space\space\space\space (2) \\ V\rightarrow \textbf{*}E\space\space\space\space (3) \\ V\rightarrow\textbf{id}\space\space\space\space (4)\\ E\rightarrow V \space\space\space\space (5) S′→S (0)S→V=E (1)S→E (2)V→*E (3)V→id (4)E→V (5)
② 由于 S ′ S' S′后面不会存在任何字符,所以其 F o l l o w Follow Follow集中只有$元素,因此产生式(0)的搜索符为$
③ 对于项目 S ′ → ⋅ S , S'\rightarrow ·\space S\space, \space S′→⋅ S , $ \space ,可以将产生式(1)代入,因为项目右部 S S S后面为空串,所以新项目的搜索符为$,故得到新项目 S → ⋅ V = E , S\rightarrow·\space V\textbf{=}E\space, \space S→⋅ V=E , $ \space ;类似地,将产生式(2)代入,得到新项目 S → ⋅ E , S\rightarrow·\space E\space, \space S→⋅ E , $
④ 对于项目 S → ⋅ V = E , S\rightarrow·\space V\textbf{=}E\space, \space S→⋅ V=E , $,可以将产生式(3)和(4)代入,因为项目右部 V V V后面为 = = =,所以新项目的搜索符为 = = =,而不是$,故得到新项目 V → ⋅ * E , = V\rightarrow·\space\textbf{*}E\space, \space= V→⋅ *E , =和 V → ⋅ id , = V\rightarrow·\space\textbf{id}\space, \space= V→⋅ id , =
⑤ 对于项目 S → ⋅ E , S\rightarrow·\space E\space, \space S→⋅ E , $,可以将产生式(5)代入,因为项目右部 E E E后面为空串,所以新项目的搜索符为$,故得到新项目 S → ⋅ V , S\rightarrow·\space V\space,\space S→⋅ V , $
⑥ 项目 V → ⋅ * E V\rightarrow ·\space\textbf{*}E V→⋅ *E和 V → ⋅ id V\rightarrow· \space\textbf{id} V→⋅ id 不会产生新的项目
⑦ 对于项目 S → ⋅ V , S\rightarrow·\space V\space,\space S→⋅ V , $,可以将产生式(3)和(4)代入,注意此时产生的新项目应该继承项目 S → ⋅ V , S\rightarrow·\space V\space,\space S→⋅ V , $的搜索符$,因此两个新项目为 V → ⋅ * E , V\rightarrow·\space\textbf{*}E\space, \space V→⋅ *E , $和 V → ⋅ id , V\rightarrow·\space\textbf{id}\space, \space V→⋅ id , $
⑧ 不妨将第一个分量相同的项目对应的搜索符集合合并一下
生成其他状态的道理类似,只展示结果。
(b) 上述状态转换图有同心项目集吗?若有,合并同心项目集后是否会出现动作冲突?
其中 I 4 I_4 I4和 I 11 I_{11} I11、 I 5 I_5 I5和 I 12 I_{12} I12、 I 7 I_7 I7和 I 13 I_{13} I13、 I 8 I_8 I8和 I 10 I_{10} I10分别为同心项目集。
同心项目集的合并(又得到LALR自动机的过程)不会引入新的移进-归约冲突,可能会引入新的归约-归约冲突;又因为规范LR(1)自动机已经解决了移进-归约冲突的问题,所以只需要验证是否存在归约-归约冲突即可。显然合并后不存在归约-归约冲突,综上,不存在动作冲突。