编译原理学习笔记(十八)~LL(1)文法

定义

        文法G被称为是LL(1)文法,当且仅当为它构造的预测分析表中不含多重定义的条目

  • 第一个L代表从左到右扫描输入序列,
  • 第二个L表示产生最左推导
  • 1表示在确定每一步 动作时向前看一个终结符。

具体怎么理解呢?
        举个简单的例子吧,通过自上而下语法分析,我们可以利用FIRST()和FOLLOW()集合构造出预测分析表,有时一个[E,a]对于的框中只有一个式子,这时候就称为LL(1)文法。因为有时会产生一个框中有两个式子对应。比如下面的例子:
在这里插入图片描述
而一般类似下面的预测分析表,我们就可以称对应的文法为LL(1)文法
注:其实就是一个框中只可以写一个式子【这样理解应该就可以啦】
在这里插入图片描述

判断是否为LL(1)文法的方法

在这里插入图片描述
解释:
这里还是举个例子说明吧,以下面的为例:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(上图为举例式子)对于条件一,假设他们的交集不为空,也就是两者的FIRST集合中存在相同的非终结符。这里我们修改一个FIRST集合:FIRST(E)={(,mod,num} FIRST(T’) = { mod} 【假设交集不为空,看看预测表有什么变化】,那么运用构造预测表的方法:我们可以发现【E’,mod】对应的框中出现了不止一个式子(可以归纳为+TE’和-TE’),所以不是LL(1)文法。

注:上述的假设其实不是完成证明条件(1),只是帮助理解。
对于条件二就比较好理解了,和条件(1)差不多的。

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
本程序的所用的存储结构都是string类型的,最主要的存储文法的数据结构为自定义结构,里面包括一个产生式的左部,右部以及select集合,至于非终结符的first和follow集合,则是定义了一个string类型的数组进行存储。 本程序的求first,follow,select集合的算法即为书上所介绍的方法,即求first的集合时,只看本产生式,求follow集合时,要进行递归查找一个非终结符的所有后跟字符,求select其实就是对first与follow集合的运算,最终根据所有的select集合,便可以判断此文法是否为LL(1)文法。 对于不是LL(1)文法的产生式,本程序在判断后进行转换,先进行消除左递归,然后提取左公因子,在这两步的每一步结束之后,都要对产生式进行整合,去掉空存储,去掉无法到达的产生式,将select全部置空。 每进行一次非LL(1)到LL(1)的转换之后,都要对其文法性质进行判断,如果是LL(1),则跳出,不是则继续,但是当循环一定次数之后仍不是,程序判定其无法转换,也要跳出。 其中还有对第一个非终结字符的右部替换与否进行选择,原因是,有些通过替换就可以很方便的进行转换,这个要通过人为进行输入。 提取公因子中也有上一段所说的类似的判断机制,目的是为了防止文法的左公因子无法提取完的情况出现。 最终有三种结果,一种是是LL(1)文法,一种是不是LL(1),但是经过转换变成了LL(1),还有一种是经过转换也无法变成LL(1)。 输入文本格式样例: A A->ad A->Bc B->aA B->bB

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

海轰Pro

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值