编译原理-求FOLLOW集合

2024-03-01 16:50
文章标签 编译 原理 集合 follow

本文主要是介绍编译原理-求FOLLOW集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

  • 为什么需要求FIRST集合:因为一个产生式存在多个候选式,选择哪一个候选式是不确定的,所以这就产生了回溯。回溯需要消耗大量的计算、存储空间,所以我们需要消除回溯。而消除回溯的其中一种方法叫作“预测”,即根据栈顶非终结符去预测后面的候选式,那预测方法就是求第一个非终结符,来判断是否和读头匹配,以达到预测的效果
  • 为什么需要求FOLLOW集合:求FOLLOW集合的目的和FIRST集合的目的是一样的,但是应该对的情形不一样,当出现了下列情形时,求FIRST集合已经达不到要求了

微信公众号:JavaWeb架构师

但是我们观察后发现,当F推出ε时,下面的E推出的a是能进行匹配的,在F这个位置求到a,就是在求FOLLOW集合

FOLLOW集合定义

  • 文字定义:FOLLOW(A)集合是所有紧跟A之后的终结符或#所组成的集合(#是句尾的标志),称FOLLOW(A)是A的随符集

  • 公式定义:
    设G是上下文无关文法,A ∈ VN,S是开始符
    微信公众号:JavaWeb架构师
    则:
    微信公众号:JavaWeb架构师

  • 注意

    • 当A是最右部的时候,# 加入 FOLLOE(A)

计算FOLLOW集合步骤

  • 求解非终结符A的随符集FOLLOW(A)
  • 1)对S,将 # 加入 FOLLOW(S),然后再按后面的处理
  • 2)若B → αAβ是G的产生式,则将FIRST(β) - ε 加入FOLLOW(A)
  • 3)若B → αA是G的产生式,或B → αAβ是G的产生式(β 多次推导后得到ε ),则将FOLLOW(B) 加入到FOLLOW(A) 【因为把B用αA替换之后,B后面紧跟的字符就是A后面紧跟的字符】
  • 4)反复使用2)-3),直到FOLLOW集合不再增大为止

  • 注意

    • 这里的文法G必须是消除左递归且提取了左因子(点击查看提取左因子的办法)

例题

  • 对如下文法G,E为开始符,求E、T、F的随符集
1.E  →  TE'
2.E'  →  +TE'
3.E'  →  ε
4.T  →  FT'
5.T'  →  *FT'
6.T'  →  ε
7.F  →  i
8.F  →  (E)

解:

---------------FOLLOW(E)---------------
FOLLOW(E) = {)} ;   // 8. 规则2)
又 ∵  E是开始符,所以FOLLOW(E) = { #,) } ;     // 规则1)---------------FOLLOW(T)---------------
FOLLOW(T) = FIRST(E') - ε; // 1.  规则2)
FIRST(E') = {+,ε};     // 2. 3.  
当E' = ε时,E  →  TE' 就是 E  →  T,所以FOLLOW(E)也要加入FOLLOW(T),
∴ FOLLOW(T) = {+, #,)}
同理,FOLLOW(E')也需要加入到FOLLOW(T)中,
FOLLOW(E') = FOLLOW(E) = { #, )};   // 1. 规则3)
∴ FOLLOW(T) = {+, #,)}---------------FOLLOW(F)---------------
与FOLLOW(F)相关的式子有:
T'  →  *FT'
T  →  FT'先,T'  →  *FT'
∴ FOLLOW(F) = FIRST(T') - ε;
FIRST(T') = {*,ε}
当T'为ε时,也要把FOLLOW(T')加入FOLLOW(F)中,
FOLLOW(T') = {+, #,)},∴ FOLLOW(F) =  {+,*, #,)}再,T  →  FT',
∴ FOLLOW(F) = FIRST(T') - ε;
当T'为ε时,也要把FOLLOW(T)加入FOLLOW(F)中,
∴ FOLLOW(F) =  {+,*, #,)}

    • 形如 T’ → *FT’,求FOLLOW(T’)时,针对本句,可以忽略3),因为是还是再求FOLLOW(T’)
    • 对于产生了ε的,一定要记得3)
    • FIRST求解的时候,关注点在左部,进行推导;FOLLOW求解的时候,关注点在右部,看跟随

其它

  • 课件下载:
关注下方微信公众号,
回复:
FOLLOW.code
  • 欢迎加入交流群:451826376

  • 更多信息:www.itcourse.top

完整教程PDF版本下载

这篇关于编译原理-求FOLLOW集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/763141

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

MySQL中的MVCC底层原理解读

《MySQL中的MVCC底层原理解读》本文详细介绍了MySQL中的多版本并发控制(MVCC)机制,包括版本链、ReadView以及在不同事务隔离级别下MVCC的工作原理,通过一个具体的示例演示了在可重... 目录简介ReadView版本链演示过程总结简介MVCC(Multi-Version Concurr

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

基于Redis有序集合实现滑动窗口限流的步骤

《基于Redis有序集合实现滑动窗口限流的步骤》滑动窗口算法是一种基于时间窗口的限流算法,通过动态地滑动窗口,可以动态调整限流的速率,Redis有序集合可以用来实现滑动窗口限流,本文介绍基于Redis... 滑动窗口算法是一种基于时间窗口的限流算法,它将时间划分为若干个固定大小的窗口,每个窗口内记录了该时间

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于