编译原理笔记9 自上而下语法分析-…

1)不带回溯的自上而下分析算法

a) 消除左递归。

i. 什么是左递归:

编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术

ii. 消除直接左递归,消除间接左递归。

b) 消除直接左递归。

   编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术

c) 消除左递归算法。

编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术注:1)若非终结符排列顺序不同,改写后的文法也不同,但它们是等价的。

d) 消除回溯

i. 产生回溯的原因:进行推导时,若产生式存在多个候选式,选择哪个候选式进行推导存在不确定性。

ii. 消除回溯的基本原则:对文法的任何非终结符,若能根据当前读头下的符号,准确的选择一个候选式进行推导,那么回溯就可以消除。注:之所以会产生回溯是因为在推导匹配的过程中存在虚假匹配。

iii. 消除回溯的方法:预测与提左因子

iv. 根据读头下符号选择候选式,使其第一个符号与读头下符号相同,或该候选式可推导出的第一个符号与读头下符号相同。这相当于向前看了一个符号,所以称为预测。注:使用了预测之后,选择候选式不再是盲目的了,所以也就无需回溯。

v. 求候选式的终结首符集。编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术

vi. 采用预测方法后PDA 的运行。编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术

vii. 提取公共左因子。编译原理笔记9 <wbr>自上而下语法分析-无回溯的自顶向下分析技术

第三次上机—语法分析1 目的:熟练掌握自上而下语法分析方法,并能用C++程序实现。 要求: 1. 使用的文法如下: E ® TE ¢ E ¢ ® + TE ¢ | e T ® FT ¢ T ¢ ® * FT ¢ | e F ® (E) | id 2. 对于任意给定的输入串(词法记号流)进行语法分析,递归下降方法和非递归预测分析方法可以任选其一来实现。 3. 要有一定的错误处理功能。即对错误能提示,并且能在一定程度上忽略尽量少的记号来进行接下来的分析。可以参考书上介绍的同步记号集合来处理。 可能的出错情况:idid*id, id**id, (id+id, +id*+id …… 4. 输入串以#结尾,输出推导过程使用到的产生式。例如: 输入:id+id*id# 输出:E ® TE ¢ T ® FT ¢ F ® id E ¢ ® + TE ¢ T ® FT ¢ …… 如果输入串有错误,则在输出要体现是跳过输入串的某些记号了,还是弹栈,弹出某个非终结符或者是终结符了,同时给出相应的出错提示信息。比如: idid*id对应的出错信息是:“输入串跳过记号id,用户多输入了一个id”; id**id对应的出错信息是:“弹栈,弹出非终结符F,用户少输入了一个id” (id+id对应的出错信息是:“弹栈,弹出终结符 ) ,用户少输入了一个右括号(或者说,括号不匹配)” 有余力的同学可进一步考虑如下扩展: 1. 将递归下降方法和非递归预测分析方法都实现 2. 在语法分析的过程调用第二次上机的结果,即利用词法分析器来返回一个记号给语法分析器。 3. 编写First和Follow函数,实现其求解过程。 测试文法: A->BCDE B->aBA|ε C->F|ε D->b|c|ε E->e|ε F->d|ε
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值