编译原理实验报告分析法.pdf

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
页眉 河南工业大学实验报告 课 程 编译原理 实验名称 实验二 LL(1)分析法 实验目的 1.掌握 LL(1) 分析法的基本原理; 2 .掌握 LL(1) 分析表的构造方法; 3 .掌握 LL(1) 驱动程序的构造方法。 一 . 实验内容及要求 根据某一文法编制调试 LL (1 )分析程序,以便对任意输入的符号串进行分析。本次实 验的目的主要是加深对预测分析 LL (1)分析法的理解。 对下列文法,用 LL (1)分析法对任意输入的符号串进行分析: (1)E-TG (2 )G-+TG (3)G- ε (4 )T-FS (5)S-*FS (6)S- ε (7)F-(E) (8)F-i 程序输入一以 # 结束的符号串 ( 包括 +* ()i#) ,如: i+i*i# 。输出过程如下: 步骤 分析栈 剩余输入串 所用产生式 1 E i+i*i# E-TG ... ... ... ... 二 . 实验过程及结果 代码如下: #includeiostream #include edge.h using namespace std; edge::edge() { cinleftright; 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;iw.length();i++) if(first.find(w[i])first.length()) first+=w[i]; 页脚

文档评论(0)

革新 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档