77范文网 - 专业文章范例文档资料分享平台

LL(1)预测分析法实验报告

来源:网络收集 时间:2019-03-09 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:或QQ: 处理(尽可能给您提供完整文档),感谢您的支持与谅解。点击这里给我发消息

编 译 原 理 实 验 报 告

一、 实验目的及要求

1. 通过本次实验,加深对LL(1)预测分析法原理的认识和理解。 2. 构造LR(1)分析程序,利用它进行语法分析,判断给出的符号串是否为该文法识别的句子。

3. 了解LR(K)分析方法是严格的从左向右扫描,和自底向上的语法分析方法。 二、 运行环境: 硬件:windows xp 软件:visual c++6.0 三、 实验内容

1、分析使用LR(1)的优点:

(1)LR分析器能够构造来识别所有能用上下文无关文法写的程序设计语言的结构。

(2)LR分析方法是已知的最一般的无回溯移进-归约方法,它能够和其他移进-归约方法一样有效地实现。

(3)LR方法能分析的文法类是预测分析法能分析的文法类的真超集。

(4)LR分析器能及时察觉语法错误,快到自左向右扫描输入的最大可能。

为了使一个文法是LR的,只要保证当句柄出现在栈顶时,自左向右扫描的移进-归约分析器能够及时识别它便足够了。当句柄出现在栈顶时,LR分析器必须要扫描整个栈就可以知道

这一点,栈顶的状态符号包含了所需要的一切信息。如果仅知道栈内的文法符号就能确定栈顶是什么句柄。LR分析表的转移函数本质上就是这样的有限自动机。不过,这个有限自动机不需要根据每步动作读栈,因为,如果这个识别句柄的有限自动机自底向上读栈中的文法符号的话,它达到的状态正是这时栈顶的状态符号所表示的状态,所以,LR分析器可以从栈顶的状态确定它需要从栈中了解的一切。 2、LR分析器由三个部分组成:

(1)总控程序,也可以称为驱动程序。对所有的LR分析器总控程序都是相同的。

(2)分析表或分析函数,不同的文法分析表将不同,同一个文法采用的LR分析器不同时,分析表将不同,分析表又可以分为动作表(ACTION)和状态转换(GOTO)表两个部分,它们都可用二维数组表示。

(3)分析栈,包括文法符号栈和相应的状态栈,它们均是先进后出栈。

分析器的动作就是由栈顶状态和当前输入符号所决定。

四、 程序源代码:

//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 %using namespace std;

edge::edge() {

cin>>left>>right; rlen=right.length();

if(NODE.find(left)>NODE.length()) NODE+=left; }

string edge::getlf() {

return left; }

string edge::getrg() {

return right; }

string edge::getfirst() {

return first; }

string edge::getfollow() {

return follow; }

string edge::getselect() {

return select; }

string edge::getro() {

string str; str+=right[0]; return str; }

int edge::getrlen() {

return right.length(); }

void edge::newfirst(string w) { int i;

for(i=0;i

if(first.find(w[i])>first.length()) first+=w[i]; }

百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库LL(1)预测分析法实验报告在线全文阅读。

LL(1)预测分析法实验报告.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印 下载失败或者文档不完整,请联系客服人员解决!
本文链接:https://www.77cn.com.cn/wenku/zonghe/504894.html(转载请注明文章来源)
Copyright © 2008-2022 免费范文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ: 邮箱:tiandhx2@hotmail.com
苏ICP备16052595号-18
× 注册会员免费下载(下载后可以自由复制和排版)
注册会员下载
全站内容免费自由复制
注册会员下载
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: