标签:没有 需要 family end ica 文法 输出 -- 开头
文法如下:
E -> TE‘
E‘ -> +TE‘|ε
T -> FT‘
T‘ -> *FT‘|ε
F -> (E)|id
----------------------------------------------------------------------------------------------------------------------------------------------------
FIRST集:由非终结符号推出的所有的开头符号或ε
规则:终结符的FIRST集,即是他本身。
所以,FIRST(+) = {+}, FIRST(*) = {*}, FIRST(id) = {id}, FIRST(() = {(}, FIRST()) = {)}
FIRST(E): 列出与E相关的产生式: E->TE‘ T -> FT‘ F -> (E)|id,
显然,F->( / id, T-> ( / id, 所以,FIRST(F) = {(,id}, FIRST(T) = {(,id}, FIRST(E) = {(,id}
FIRST(E‘) = {+,ε}
FIRST(T‘) = {*,ε}
FOLLOW集:紧跟随其后面的终结符号或#
和FIRST集不同的是:FOLLOW集只是针对非终结符而言,因为FIRST集和FOLLOW集设计的初衷就是
根据当前句型的最左语法变量A和当前输入符号a可以唯一的选择A的候选式αi来替换A,
从而实现对G的句子进行确定的自顶向下分析。所以终结符可以直接与输入符号进行匹配,不需要FOLLOW集。
实现:把所有包含你要求的符号的产生式都找出来。
FOLLOW(E): F -> (E)|id, E后面就是),其他包含E的都没有,所以FOLLOW(E)={),#}
FOLLOW(E‘): 由 E -> TE‘ 和 F -> (E)|id 推出 F -> (TE‘)|id ,所以FOLLOW(E)={),#}
FOLLOW(T): 由 E -> TE‘ 和 E‘ -> +TE‘|ε ,T后面是E‘ (即:+TE‘|ε),所以,T有+,
再根据F -> (E)|id E -> TE‘ 推出 F -> (TE‘)|id,当 E‘ -> ε时,T后面是),所以,T有 ).
故FOLLOW(T) = {+,),#}
FOLLOW(T‘): 由 E -> TE‘ 和 F -> (E)|id 推出 F -> (TE‘)|id,且 T -> FT‘,所以 F -> (FT‘E‘)|id
T‘ 后面紧跟 E‘,E‘ -> +TE‘|ε,当E‘ -> +TE‘时,T‘ 有 +。当E‘ -> ε 时,T‘ 有 )
故FOLLOW(T‘) = {+,),#}
FOLLOW(F): 由 E -> TE‘ 和 F -> (E)|id 推出 F -> (TE‘)|id,且 T -> FT‘ ,T‘ -> *FT‘|ε,所以 F -> (FT‘E‘)|id
当 T‘ -> *FT‘时,F有 *,当T‘ -> ε时,F后紧跟E‘,当E‘ -> +TE‘时,F有 +,当E‘ -> ε时,F 有 )
故FOLLOW(F) = {*,+,),#}
标签:没有 需要 family end ica 文法 输出 -- 开头
原文地址:http://www.cnblogs.com/standby/p/6792774.html