编译原理复习——语法分析(自顶向下)
admin
2024-01-18 17:28:35
0
自顶向下的语法分析定义: 从文法的开始符号出发,反复使用文法的产生式,寻找与输入符号串匹配的推导。 语法树的构造 将文法的开始符号作为语法树的,向下逐步建立语法树,使语法树的末端结点符号串正好是输入符号串。 所以解决这个问题的核心在于如何找到合适的产生式 从文法的开始符出发,如能根据当前的输入符号(单词符号)唯一地确定选用哪个产生式进行推导,则分析是确定的。 LL(1)文法是我们在语法分析自顶向下中所希望遇到的文法,我们在遇到判断一个文法是不是LL(1)前我们需要先学习三个集合即: 开始符号集FIRST 后跟符号集FOLLOW 选择集合SELECT FIRST集合 定义: G=(VN , VT , P, S)是上下文无关文法    α→βVN , β∈(VN∪VT )* ) FIRST(β) = {a | a ∈VT 且β* a......}     若β* ε 则规定ε FIRST(β) 直观上说文法符号串β 的开始符号集是由β推导出的所有的终结符开头可能的ε组成。 例题:
文法G 2 [S]:
S→Ap
S→Bq
A→a
A→cA
B→b
B→dB
求出每条规则右部的符号串的FIRST集合

FIRST(Ap)={a,c}
FIRST(Bq)={b,d}
FIRST(a)={a }
FIRST(cA)={c}
FIRST(b)={b}
FIRST(dB)={d}
这里注意一点在求FIRST集合时很多时候会忘了ε,如果推导不出来那就没关系但是如果可以推导出来的话一定要写上。
FLLOW集合 定义 :
G=(V N , V T , P, S) 是上下文无关文法  B→xAy , (A, B ∈ V N , x,y∈(VN∪ V T )* )
FOLLOW(A)={a|S=>*…Aa… , a ∈ V T } ,  若有 S=>* …A ,则规定 # ∈ FOLLOW(A)

注:输入串 # ,‘ # ’做为输入串的结束符
直观上说,非终结符A的后跟符号集是由句型中紧跟A后的那些 终结符 (包括 # )组成
FOLLOW(A) 的计算方法
1 如果 A 为文法的识别符号,则规定 # ∈ FOLLOW(A)
2 如果有形如 B→α Aβ 的规则,则 FIRST(β) 的非空元素 ∈ FOLLOW(A)
3 如果有 β=>*ε ,或者形如 B→α A 的规则,则 把 FOLLOW(B) 加入到 FOLLOW(A) 中
反复使用上述规则,直到每个非终结符的 FOLLOW 集不再增大为止

之所以说这个复杂跟他的第3条规则有很大的关系反复使用这个规则在计算中会很复杂。 注意哦在FOLLOW集合中我们是没有ε的只有# 例子:
文法 G 3 [S]: S→aA|d    A→bAS|ε
FOLLOW(A)=Follow(S) ∪ {FIRST(S)-{ ε }} ={#} ∪{a,d} ={#, a, d}
FOLLOW(S)= {#} ∪ FOLLOW(A) ={#, a, d}

   SELECT 集合定义: 这个是跟之前的FIRST集合和FOLLOW集合是有很大关系的。
G=(V N , V T , P, S) 是上下文无关文法
A → β , (A ∈ V N , β ∈ (V N∪ V T )* )
若 β ≠>*ε, 则 SELECT(A→β)=FIRST(β)
若 β=>*ε, 则 SELECT(A→β)=(FIRST(β)-{ε} ) ∪ FOLLOW(A)
例子:
G 3 [S]:
S→aA
S→d
A→bAS
A→ε
SELECT(S→aA)=FIRST(aA)={ a }
SELECT(S→d)=FIRST(d)={ d }
SELECT(A→bAS)=FIRST(bAS)={ b }
SELECT(A→ε) =(FIRST(ε)-{ε})+ FOLLOW(A)={ #,a,d }
注意哦在SELECT集合中我们是没有#的只有ε 现在我们可以讨论LL(1)文法了 首先是部分定义 一个上下文无关文法为LL(1)文法的充分必要条件,对每个非终结符A的两个不同产生式A→α与A→β满足SELECT(A→α)∩SELECT(A→β)=Φ LL(1)文法的含义 第一个L——从左到右扫描输入串 第二个L——分析过程用最左推导 (1)——表明只需向前看 1 个输入符号便可以决定选哪个产生式进行推导(类似地,LL(k) 文法则需要向前k 个输入符号才可以确定选用哪个产生式) 要判别一个上下文无关文法是否是LL(1)法,分为五步: 求能推出ε的非终结符集 计算每个产生式右部βFIRST(β) 计算每个非终结符AFOLLOW(A) 计算每个产生式A→βSELECT(A→β) LL(1)文法的定义判别

相关内容

热门资讯

小米安卓7.0系统特点,创新体... 你知道吗?最近小米手机的新系统安卓7.0可是火得一塌糊涂呢!作为一个紧跟科技潮流的数码爱好者,我当然...
安卓老系统怎么下载软件,轻松找... 你那安卓老系统是不是有点儿落伍了?别急,今天就来给你支个招,教你怎么下载那些新鲜出炉的软件,让你的手...
安卓系统升级鸿蒙系统后app,... 你知道吗?最近手机界可是掀起了一股不小的风潮呢!那就是安卓系统升级到鸿蒙系统后,那些我们熟悉的app...
阿里os系统能装安卓 你知道吗?最近在科技圈里可是掀起了一股热潮,那就是阿里OS系统能装安卓的消息。这可不是什么小道消息,...
香橙派one安卓系统,轻巧便携... 你有没有听说过香橙派One这款小玩意儿?它可是最近在科技圈里火得一塌糊涂呢!想象一个迷你电脑,却能装...
怎么恢复到安卓系统,重拾流畅体... 手机用久了,是不是突然觉得卡得要命,想给它来个“大变身”?别急,今天就来教你怎么把安卓手机恢复到原厂...
魅族系统基于安卓5.0,基于安... 亲爱的数码爱好者们,今天我要和你聊聊一个特别的话题——魅族系统。你可能已经知道,魅族手机以其独特的F...
安卓系统触屏的手机,便捷操作与... 你有没有发现,现在市面上几乎每个人手里都拿着一部安卓系统触屏的手机?这玩意儿真是越来越普及了,就像空...
安卓系统如何免费安装,轻松上手... 你有没有想过,你的安卓手机其实可以更加个性化,更加高效呢?没错,今天就要来跟你聊聊如何免费安装安卓系...
如何删除安卓系统的屏保,安卓系... 手机屏幕上那美美的屏保,是不是有时候让你觉得有点烦呢?想要摆脱它的束缚,让它不再霸占你的视线?别急,...
安卓仿Windows系统全套,... 你有没有想过,如果你的安卓手机能像Windows电脑一样操作,那会是怎样的体验呢?想象你可以在安卓手...
安卓6.0系统什么意思,全面解... 你有没有听说过安卓6.0系统?这可是智能手机界的一件大事呢!想象你的手机就像是一个聪明的小助手,不仅...
小米8不是安卓系统吗,揭秘非安... 你知道吗?小米8这款手机,很多人都会好奇,它不是安卓系统吗?今天,我们就来深入探讨一下这个问题,揭开...
安卓九系统刷机包,体验流畅升级... 你有没有发现,安卓九系统自从更新以来,就成为了众多手机用户的新宠儿?这不,最近我手头的这部手机也迫不...
手机安卓系统的哪个好点,安卓系... 说到手机安卓系统,这可是个让人纠结的话题呢!市面上那么多品牌,每个品牌下的系统又各有特色,真是让人挑...
安卓更改最小系统声音,深度解析... 你有没有发现,手机里的安卓系统有时候发出的声音真是让人又爱又恨呢?有时候一个简单的提示音,就能让你瞬...
安卓系统4.4.2手机 你有没有发现,身边的朋友都在用各种花里胡哨的手机,而你还在坚守着你的安卓系统4.4.2手机?别看它外...
安卓系统总是更新好吗,持续优化... 你有没有发现,每次打开手机,安卓系统总是一副“我更新了,我更新了”的兴奋样?这让人不禁想问:安卓系统...
安卓系统怎么不跑流量吗,轻松管... 手机里的流量总是不知不觉就跑光了,是不是你也和我一样,对安卓系统的流量消耗问题感到头疼呢?别急,今天...
安卓系统手机塔防游戏,守护家园 你有没有发现,最近你的安卓手机里多了一款特别好玩的游戏?没错,就是塔防游戏!这种游戏不仅考验你的策略...