follow集求法有两种,要么逐步推导,推导出所有式子求follow集合,这种方法简单但是容易遗漏
要么就按照步骤一步一步来求
文字定义:FOLLOW(A)集合是所有紧跟A之后的终结符或#所组成的集合(#是句尾的标志),称FOLLOW(A)是A的随符集
计算所有非终结符号A的follow(A)集合时,不断应用下面的规则,直到再没有新的终结符号可以被加入到任意的follow集合中为止。
注意:当A是最右部的时候,将$加入到follow(A)中
(1)将 $ 放到follow(S)中,其中S是文法的开始符号。
(2)如果存在一个产生式A→αBβ,那么first(β)中除ε之外的所有符号都在follow(B)中。 【 follow(B)是求跟在B后的终结符或$组成的集合,因此对于跟在B后的β,它的first集合就是follow(B)的子集 】
(3)如果存在一个产生式A→αB,或存在产生式A→αBβ且first(β)包含ε,那么follow(A)中的所有符号都在follow(B)中。 【 对于A→αBβ,且β多步推导出ε ,那么可以用αB替换A, B后面紧跟的字符就是A后面紧跟的字符】
文法如下:
直接给出First集
first(E) = first(T) = first(F) = { ( , id }
first(E’) = {+, ε}
first(T’) = {*, ε}
E是文法的开始符号,根据规则 (1) 将$加入到 follow(E), follow(E) = { $ },
再根据规则(2)和产生式 5 将 ) 加入, 所以 follow(E) = {$, )}
根据产生式 1 , E'是结尾符号,所以将$加入follow(E’)中 , 根据规则 (3) 和产生式 1,可知,将
follow(E) 加入到 follow(E‘)中 ,所以 follow(E') = {$, )}
根据产生式 1 和 规则(2) ,将first(E') - {ε}加入到follow(T)中,follow(T) = {+} ,
再根据产生式 2 和规则(3), 将follow(E)加入到follow(T)中,所以follow(T) = {+, ), $}
根据产生式 3 因为T'出现在最右部,所以{$}加入follow(T‘)中,再根据规则(3)和产生式3,
将follow(T)加入到follow(T’)中,所以follow(T') = {+, ), $}
① 根据产生式 3 和规则 (2),将first(T')-{ε}加入到follow(F)中,follow(F) = {*}
② 产生式 3 和 规则 (3) ,将follow(T)加入到follow(F)中,follow(F) = {*,+,),$}
③ 再根据产生式 4 和规则(3)将follow(T')加入follow(F) follow(F) = {+, ), *, $}
④ 根据产生式 4 和规则2 将first(T')加入到follow(F)中, follow(F) = {+,),*,$}
实际上,我们回顾规则开头,当没有新的终结符加入时,不必对所有的式子都应用
式子进行计算。