编译原理LL1语法分析实验报告 编译原理语法树.docx

上传人:b****6 文档编号:6316460 上传时间:2023-01-05 格式:DOCX 页数:9 大小:19.53KB
下载 相关 举报
编译原理LL1语法分析实验报告 编译原理语法树.docx_第1页
第1页 / 共9页
编译原理LL1语法分析实验报告 编译原理语法树.docx_第2页
第2页 / 共9页
编译原理LL1语法分析实验报告 编译原理语法树.docx_第3页
第3页 / 共9页
编译原理LL1语法分析实验报告 编译原理语法树.docx_第4页
第4页 / 共9页
编译原理LL1语法分析实验报告 编译原理语法树.docx_第5页
第5页 / 共9页
点击查看更多>>
下载资源
资源描述

编译原理LL1语法分析实验报告 编译原理语法树.docx

《编译原理LL1语法分析实验报告 编译原理语法树.docx》由会员分享,可在线阅读,更多相关《编译原理LL1语法分析实验报告 编译原理语法树.docx(9页珍藏版)》请在冰豆网上搜索。

编译原理LL1语法分析实验报告 编译原理语法树.docx

编译原理LL1语法分析实验报告编译原理语法树

【编译原理LL

(1)语法分析实验报告】编译原理语法树

精品文档

精品文档

学号专业计算机科学与技术姓名万学进

试验日期2021-5-11教师签字成果

实验报告

【试验名称】LL〔1〕语法分析

【试验目的】

通过完成预报分析法的语法分析程序,了解预报分析法和递归子程序法的区分和联系。

使了解语法分析的功能,把握语法分析程序设计的原理和构造方法,训练把握开发应用程序的基本方法。

【试验内容】

依据某一文法编制调试LL〔1〕分析程序,以便对任意输入的符号串进行分析。

构造预报分析表,并利用分析表和一个栈来实现对上述程序设计语言的分析程序。

分析法的功能是利用LL〔1〕操纵程序依据显示栈栈顶内容、向前看符号以及LL〔1〕分析表,对输入符号串自上而下的分析过程。

【设计思想】

〔1〕定义部分:

定义常量、变量、数据结构。

〔2〕初始化:

设立LL

(1)分析表、初始化变量空间〔包括堆栈、结构体、数组、临时变量等〕;

〔3〕操纵部分:

从键盘输入一个表达式符号串;

〔4〕利用LL

(1)分析算法进行表达式处理:

依据LL

(1)分析表对表达式符号串进行堆栈〔或其他〕操作,输出分析结果,假如遇到错误则显示错误信息。

【试验要求】

1、编程时留意编程风格:

空行的使用、注释的使用、缩进的使用等。

2、假如遇到错误的表达式,应输出错误提示信息。

3、对以下文法,用LL〔1〕分析法对任意输入的符号串进行分析:

〔1〕S-TE

〔2〕E-+TE|$

〔3〕T-FM

〔4〕M-*FM|$

〔5〕F-(E)|i][10],BlankTerminate[20][2];

charFirst[5][4]={S,(,i,\0,

E,+,$,\0,

T,(,i,\0,

M,*,$,\0,

F,(,i,\0};

charFollow[5][6]={S,),,\0,\0,

E,),,\0,\0,

T,+,),,\0,

M,+,),,\0,

F,*,+,),};

charSelect[8][4]={(,i,\0,\0,

+,\0,\0,\0,

),,\0,

(,i,\0,\0,

*,\0,\0,\0,

+,),,

(,\0,\0,\0,

i,\0,\0,\0};

intIndiBlanket[6][7];

charVT[10]={i,+,*,(,),,j=0;

while(!

feof(fp))

{

fscanf(fp,%c,singleChar);

if(singleChar==;

break;

}

if(singleChar==\n)

{

Grammar[i][j]=\0;

i++;

j=0;

continue;

}

if(singleChar==-)

{

tp=fp;

fscanf(tp,%c,nextChar);

if(nextChar==)

{

fp=tp;

continue;

}

}

if(singleChar==|)

{

Grammar[i+1][0]=Grammar[i][0];

Grammar[i][j]=\0;

i++;

j=1;

continue;

}

Grammar[i][j]=singleChar;

j++;

}

//printf(输入的文法:

\n);

for(intk=0;k=i;k++)

{

j=0;

while(Grammar[k][j]!

=\0)

{

if(j==1)

{

//printf(-);

}

//printf(%c,Grammar[k][j]);

j++;

}

//printf(\n);

}

//printf(%d\n,i);

fclose(fp);

returni;

}

intFill(chargi,charsij,intgrammarOrder)

{

inti,j;

for(i=0;ivnNum;i++)

{

if(First[i][0]==gi)break;

}

j=0;

while(VT[j]!

=\0)

{

if(VT[j]==sij)break;

j++;

}

IndiBlanket[i][j]=grammarOrder;

return0;

}

intIndicate()

{

inti,j;

for(i=0;ivnNum;i++)

{

for(j=0;jvtNum;j++)

{

IndiBlanket[i][j]=-1;

}

}

for(i=0;i=grammarNum;i++)

{

j=0;

while(Select[i][j]!

=\0)

{

Fill(Grammar[i][0],Select[i][j],i);

j++;

}

}

printf(预报分析表如下:

\n);

for(i=0;ivnNum;i++)

{

for(j=0;jvtNum;j++)

{

printf(%3d,IndiBlanket[i][j]);

}

printf(\n);

}

return0;

}

intTerminate_$(intgrammarNum)

{

intj=0;

intcount;

for(inti=0;i=grammarNum;i++)

{

BlankTerminate[i][1]=0;

}

BlankTerminate[0][0]=Grammar[0][0];

if(Grammar[0][1]==$)

{

BlankTerminate[0][1]=1;

}

count=1;

for(i=1;i=grammarNum;i++)

{

for(j=0;jcount;j++)

{

if(Grammar[i][0]==BlankTerminate[j][0])

{

if(Grammar[i][1]==$)

{

BlankTerminate[j][1]=1;

break;

}

}

}

if(j==count)

{

BlankTerminate[count][0]=Grammar[i][0];

if(Grammar[i][1]==$)

{

BlankTerminate[count][1]=1;

}

count++;

}

}

count--;

//printf($的终结符表:

\n);

/*

for(i=0;ij;i++)

{

printf(%c:

%c\n,BlankTerminate[i][0],BlankTerminate[i][1]);

}

*/

returncount;

}

AnalStackInitStack()

{

S.base=(char*)malloc(100*sizeof(char));

if(!

S.base)exit

(1);

S.top=S.base;

S.stacksize=100;

*S.top=)

{

printf(%c,AnalStr[i]);

i++;

}

printf(\t\t);

if(sign==0)

{

intj=0;

while(Grammar[order][j]!

=\0)

{

printf(%c,Grammar[order][j]);

if(j==0)printf(-);

j++;

}

printf(\n);

}

if(sign==1)

{

printf(%c匹配\n,AnalStr[startpos]);

}

return0;

}

intPush(chartopChar,charcurChar,intsign,intii,charAnalStr[])

{

inti,j;

for(i=0;ivnNum;i++)

{

if(First[i][0]==topChar)break;

}

j=0;

while(VT[j]!

=\0)

{

if(VT[j]==curChar)break;

j++;

}

order=IndiBlanket[i][j];

Print(AnalStr,ii,sign);

j=1;

while(Grammar[order][j]!

=\0)

{

j++;

}

j--;

while(j!

=0)

{

if(Grammar[order][j]!

=$)

{

S.top++;

*S.top=Grammar[order][j];

}

j--;

}

return0;

}

intAnalysis()

{

inti=0;

intsign=0;

intcount=1;

charcurChar;

InitStack();

charAnalStr[10]={\0};

printf(输入产生式:

\n);

scanf(%s,AnalStr);

printf(步骤\t分析栈\t剩余输入串\t产生式\n);

while(AnalStr[i]!

=\0)

{

sign=0;

curChar=AnalStr[i];

char*p=S.top;

chartopChar=*p;

S.top--;

if(topCharA||topCharZ)

{

if(topChar==curChar)

{

sign=1;

Print(AnalStr,i,sign);

i++;

continue;

}

else

{

printf(AnalysisERROR!

\n);

return0;

}

}

if(topChar==;

}

}

else

{

Push(topChar,curChar,sign,i,AnalStr);

}

}

printf(预报分析胜利!

\n);

return0;

}

intmain()

{

inti,m;

grammarNum=ScanGrammar();

vnNum=Terminate_$(grammarNum);

//printf(Select集:

\n);

for(i=0;i=grammarNum;i++)

{

m=0;

while(Select[i][m]!

=\0)

{

//printf(%c,Select[i][m]);

m++;

}

//printf(\n);

}

Indicate();

Analysis();

return0;

}

【运行结果】

售后服务方案(赠送)

1.售后服务概述

公司长期以来始终致力于提供高质量、完善的支持服务,确保用户的系统稳定运行。

公司拥有一批资深的施工人员,具有丰富的阅历,能够很好的解决设备各类故障,强大的用户支持队伍和良好的用户中意度是我们的一大优势。

维护打算及承诺 

?

一、项目售后服务内容承诺 

我公司贯彻执行:

“诚信正直、成就客户、完善自我、追求卓越〞的宗旨,对于已经竣工、验收合格的项目进行质量跟踪服务,本着技术精益求精的精神,向用户奉献一流的技术和一流的维护服务。

我公司假如承接了端拾器项目,将严格遵循标书及合同的规定,在保证期内向业主提供该项目的责任和义务。

在保修期之后,考虑到设备维护的连续性,建议业主与我公司签订维护合同,以确保此系统项目的正常运行所必需的技术支持和管理支持。

二、服务与保证期 

?

在项目验收合格之日起,开始进行售后服务工作,包括以下几个方面:

1、售后服务期; ?

2、维护人员; 3、售后服务项目;4、服务响应时间。

?

三、售后服务期 

?

在项目验收合格之日起,即进入了售后服务期。

售后服务期=质量保证期+质量维护期

?

质量保证期:

在质量保证期内,如因质量问题造成的故障,实行免费更换设备、元器件及材料。

如因非质量因素造成的故障,收取更换设备、元器件及材料本钱费。

质量维护期:

在质量保证期之后,即自行进入质量维护期。

我方对所承当端拾器项目提供终身质量维护服务,以不高于本合同设备单价的优惠价格提供所需更换的元器件及材料,另收维护人员工本费。

四、具体措施承诺 

?

1、首先在签订项目合同的同时与客户签订售后服务保证协议书,排除客户的后顾之忧,对客户做出实事求是的、客观的承诺。

2、对已阅历收合格交付用户的端拾器项目,在合同期内与用户进行联系,记录用户使用状况,系统运行状况等进行质量跟踪调查,变被动服务为主动服务。

3、对已交工的端拾器项目建立系统运行档案,并进行质量跟踪。

4、系统运行档案记录其端拾器项目运行状况、各类设备使用状况、操作人员操作水平状况及人员流淌状况。

5、针对各用户单位操作人员出现的代表性问题,定期对操作人员进行技术培训或到现场培训及指导。

6、正在使用中的系统、设备出现故障时,公司修理服务人员接到报告后准时赴现场处理、修理。

7、对于运行时间较长的端拾器项目,公司修理服务人员定期与客户进行联系询问状况,定期到客户方进行巡察、检查,并做出记录,记录归档保存。

8、施工保证

将选派具有丰富阅历的技术人员负责端拾器项目具体施工,保证安装质量及系统使用功能,并保证整个系统运行平稳、高效、可靠。

9、系统保修

作为项目承包单位,我公司将严格遵循招标文件及合同的规定,向业主提供端拾器项目最终验收合格之日起,在保质期范围内免费修理。

10、保修期内设备损坏,经鉴定为设备本身缘由造成的故障,我方负责免费修理或者更换;同时负责在保修期内定期对设备提供保养维护服务。

总之,为使业主使用放心、使用方便、保证端拾器项目正常运行,公司全体技术、维护人员本着客户第一的原则,全心全意地为客户着想,全力以赴的进行工作,让我们共同携手,为制造美妙的明天而努力工作。

五、保修服务内容及范围

我公司将为所承当的各个端拾器项目提供保修服务,有效期从项目验收后,业主在竣工报告上签字之日起。

1、响应时间:

具体的响应时间将按故障级别划分;

2、修理地点:

用户现场。

我公司负责实施的全部系统项目,在正常环境下做适当使用时所发生的故障,我公司将提供商定保修服务。

非当前故障,我公司支配提供服务,但需按收费标准另收费用。

我公司的保修服务仅限于经我公司认定的合格产品。

所谓不合格的产品包括:

非经我公司供应的产品、非经我公司认定合格的产品及顾客不同意我公司做功能改良的产品。

以下状况所发生的系统损害不包括在保修服务范围内:

1、使用不适当的工具进行系统维护时造成的系统设备损坏;

2、现场环境不符合我公司建议的规范;

3、意外、自然灾难、疏忽及不当使用、战争、暴动、罢工、雷击或电力故障、顾客搬运不当的损坏,经由非我公司人员或其授权的子承包商对系统进行修改和变动;

4.设备的维护和信息处理方式。

六、系统维护

1、系统运行管理工作

为了保证系统能够长时间的正常运行,我们将进行完善的系统培训,同时制定各个系统项目操作规程,并协作业主制定操作人员责任界面及合理的交接班制度。

2、系统维护保养

我公司的售后服务人员在维护期内将对贵方的系统项目提供服务,使它们保持良好的运行状态。

?

3、月度保养

?

 坚持月度维护保养,保证每个系统项目机械装置保持最正确工作状态。

七、维护及服务支持措施

1、电话支持服务

电话服务热线号码以我方提供给业主的号码为准(包括电话和传真号码)。

如有更改,我方至少在自更改之日起3天内以电子邮件、传真、电话的方式通知业主。

2、现场排除故障或技术指导

我方在接到业主的电话支持服务请求后,假如不能通过电话支持服务解决设备或产品发生的技术故障,且经双方商议 确认需要进行现场支持的状况下,我方将派专业项目技术人员准时前往现场帮助业主排除故障。

3、电话咨询服务

对业主在使用设备或产品过程中产生的非故障类问题,我方提供电话咨询服务。

4、投诉受理服务

我方在公司设有用户投诉电话

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 自然科学 > 化学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1