编译原理算符优先算法语法分析实验报告.docxVIP

编译原理算符优先算法语法分析实验报告.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
学号姓名 学号 姓名 成绩 算符优先分析法分析器的设计 实验日期 年级专业 实验题目 一、 实验目的: 设计一个算符优先分析器,理解优先分析方法的原理。 二、 实验要求: 设计一个算符优先分析器 三、 实验内容: 使用算符优先分析算法分析下面的文法: E’ → #E# E → E+T | T T → T*F | F F → P^F | P P → (E) | i 其中 i 可以看作是一个终结符,无需作词法分析。具体要求如下: 1、如果输入符号串为正确句子,显示分析步骤,包括分析栈中的内容、优先关系、输入符号串的变化情况; 2、如果输入符号串不是正确句子,则指示出错位置。 四、 实验结果及主要代码: 主 要 代 码 void operatorp() { char s[100]; char a,Q; int k,j,i,l; string input,temp; cininput; cout 步 骤 \t 栈 \t 优 先关 系 \t 当前 符号 \t 剩 余输 入 串 \t 移进或归约 endl; k=1;s[k]=#;i=1; do { a=input[0]; temp=; for(l=1;l();l++) temp+=input[l]; input=temp; if(svt(s[k])) j=k; else j=k-1; while (search(s[j],a)==) { cout(i)\t; // 步骤 temp=; for(l=1;lk+1;l++) temp+=s[l]; couttemp\t; // 栈 cout\tsetw(10); // 优先关系 couta\tsetw(15); coutinput\tsetw(15); // 当前符号 // 剩余输入串 i++; for(;;) { Q=s[j]; if(svt(s[j-1])) j=j-1; else j=j-2; if(search(s[j],Q)==) { cout 归约 endl;// 归约 break; } } temp=; for(l=j+1;lk+1;l++) temp+=s[l]; for(l=0;l6;l++) if(temp==key[l]) { k=j+1; s[k]=v[l]; break; } } cout(i)\t; // 步 骤 temp=; for(l=1;lk+1;l++) temp+=s[l]; couttemp\t; // 栈 if(search(s[j],a)==) { cout\tsetw(10);; // 优先关系 couta\tsetw(15); // 当前符号 coutinput\tsetw(15); // 剩余输入串 cout 移进 endl; i++; k=k+1;s[k]=a; } // 移进 else if(search(s[j],a)==Y) { cout=\tsetw(10);; // 优先关系 couta\tsetw(15); // 当前符号 coutinput\tsetw(15); // 剩余输入串 cout 接受 endl; i++; } else { cout\tsetw(10);; // 优先关系 couta\tsetw(15); // 当前符号 coutinput\tsetw(15); // 剩余输入串 cout 出错 endl; exit(0); }// 出错 }while(a!=#); } 实验结果

文档评论(0)

小光老师 + 关注
官方认证
文档贡献者

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

认证主体赛罕区发光网络技术服务部
IP属地内蒙古
统一社会信用代码/组织机构代码
92150105MAC8HM2M1T

1亿VIP精品文档

相关文档