FIRST集和FOLLOW集的计算

本文探讨了在语法分析过程中至关重要的FIRST集和FOLLOW集的计算方法。详细介绍了如何通过推导出所有可能的串首终结符来构建FIRST集,并提供了一个具体的计算流程。同时,文章还讲解了FOLLOW集的计算算法,帮助读者深入理解这两个集合在编译原理中的应用。
摘要由CSDN通过智能技术生成

FIRST集的计算

计算FIRST(x)

  • FIRST(X):可以从X中推导出的所有串首终结符构成的结合。
  • $X\Rightarrow^*{\epsilon}$,那么$\epsilon \in FIRST(X)$

image

推导过程:

  1. (2)、(4)、(5)的产生式都是以非终结符开头,于是直接分别将$+,\epsilon$$*,\epsilon$$(, id$加入到它们各自的FIRST集中。
  2. (1)中开头的是非终结符T,于是它的FIRST集取决于T的FIRST集
  3. (3),同上,它的FIRST集需要依赖F的FIRST集,即$(, id$
  4. 于是(1)的FIRST集也是$(, id$

具体算法

image

题目:FirstFollow生成算法模拟 【问题描述】 设计一个由正规文法生成FirstFollow并进行简化的算法动态模拟。(算法参见教材) 【基本要求】 动态模拟算法的基本功能是: (1) 输入一个文法G; (2) 输出由文法G构造FIRST的算法; (3) 输出First; (4) 输出由文法G构造FOLLOW的算法; (5) 输出FOLLOW。 【测试数据】 输入文法: E->TE’ E’->+TE’|ε T->FT’ T’->*FT’|εF->(E)|i 【实现提示】 用数据库存储多行文法,用LIST控件显示算法,用GRID类依据算法进行作图。并实现算法与生成过程的关联。 三、设计思路 该分析器主要包括三大部分:求FIRST,求FOLLOW,求SELECT。下面主要介绍计算FIRSTFOLLOW算法思想。 求FIRST的算法思想:主要有三个函数 First(), First_getvn(), First_getvt。函数 First()调用First_getvn(),First_getvn()调用First_getvt 这里主要把产生式分成的两种: 一:产生式只能推出空,形如:S->$;此时S的FIRST为{$} 二:产生式右部包含非终结符和终结符,形如:S->aA, S->AB. 这里定义了两个比较重要字符串,分别是first 即FIRST;另一个是first_vn,把它定义非终结符的FIRST。当产生式右边的第一个字符为非终结符时,把该VN加入 srt first_vn中,后再调用函数first_getvt求出FIRST。若产生式右边的第一个字符为终结符时,则直接把该VT加入str first,得到FISRT。 流程图: 略
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值