2020年LL(1)预测分析法实验报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
精品资料
编
译
原
理
实
验
报
告
可编辑修改
精品资料
一、实验目的及要求
通过本次实验,加深对 LL(1) 预测分析法原理的认识和理解。
构造 LR(1) 分析程序,利用它进行语法分析,判断给出的符号串是否为该文法识别的句子。
了解 LR(K)分析方法是严格的从左向右扫描,和自底向上的
语法分析方法。
二、运行环境
硬件 windows xp
软件 visual c++0
三、实验内容
1 、分析使用 LR(1) 的优点
(1)LR 分析器能够构造来识别所有能用上下文无关文法写的
程序设计语言的结构。
(2)LR 分析方法是已知的最一般的无回溯移进-归约方法,它
能够和其他移进 -归约方法一样有效地实现。
(3)LR 方法能分析的文法类是预测分析法能分析的文法类的
真超集。
(4)LR 分析器能及时察觉语法错误, 快到自左向右扫描输入的
最大可能。
可编辑修改
精品资料
为了使一个文法是 LR 的,只要保证当句柄出现在栈顶时,自左向右扫描的移进 -归约分析器能够及时识别它便足够了。当句柄出现在栈顶时, LR 分析器必须要扫描整个栈就可以知道这一点,栈顶的状态符号包含了所需要的一切信息。
如果仅知道栈内的文法符号就能确定栈顶是什么句柄。
LR 分析表的转移函数本质上就是这样的有限自动机。
不过,这个有限自动机不需要根据每步动作读栈,因为,如果这个识别句柄的有限自动机自底向上读栈中的文法符号的话,它达到的状态正是这时栈顶的状态符号所表示的状态,所以, LR 分析器可以从栈顶的状态确定它需要从栈中了解的一切。
2 、LR 分析器由三个部分组成
总控程序,也可以称为驱动程序。
对所有的 LR 分析器总控程序都是相同的。
分析表或分析函数,不同的文法分析表将不同,同一个文法采用的 LR 分析器不同时,分析表将不同,分析表又可以分为动作表( ACTION )和状态转换( GOTO )表两个部分,它们都可用二维数组表示。
分析栈,包括文法符号栈和相应的状态栈,它们均是先进后出栈。
分析器的动作就是由栈顶状态和当前输入符号所决定。
四、程序源代码
可编辑修改
精品资料
//edge.h
#ifndef HEAD_EDGE
#define HEAD_EDGE
#include
using namespace std; extern int SUM;
extern string NODE,ENODE; class edge
{
public:
edge();
string getlf();
string getrg();
string getfirst();
string getfollow();
string getselect();
string getro();
int getrlen();
void newfirst(string w);
void newfollow(string w);
void newselect(string w);
void delfirst();
private:
string left,right,first,follow,select;
int rlen;
};
#endif
///////////////////////////////////////////////////////// ////////////////////
//edge.cpp
#include
#include "edge.h"
using namespace std;
edge::edge()
可编辑修改
精品资料
{
cin>>left>>right;
rlen=right.length();
if(NODE.find(left)>NODE.length())
NODE+=left;