- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验二 表达式语法分析设计
实验二: 表达式语法分析设计
一、实验目的:
熟悉并设计一个表达式的语法分析器
二、实验内容:
1.设计表达式的语法语法分析器算法
2.编写代码并上机调试运行通过
要求: 输入------------ 表达式
输出------------ 表达式语法是否正确
三、概要设计
采用递归子程序法分析加乘二元表达↓式运算的语法正确性.
程序中表达式文法为:
E-T|E+T
T-T*F|F
F-(E)|i
增加一个产生式:Z-E
流程图:
根据上述流程图的算法,通过子程序的递归调用对二元表达式的语法进行分析.
说明: 本程序只能对加乘二元运算进行语法分析,用i来表示数值.
以#作为结束符.
四﹑源代码设计
#include stdio.h
#include malloc.h
void E();
void F();
void T();
void T1();
void E1();
struct Lchar{
char char_ch;
struct Lchar *next;
}Lchar,*p,*h,*temp;
char ch;
int right;
void E(void) //E-T|E+T
{
T();
E1();
}
void T(void) //T-F|T*F
{
F();
T1();
}
void T1(void) //
{
if(h-char_ch==*){
h=h-next;
F();
T1();
}
else
if(h-char_ch!=#h-char_ch!=)h-char_ch!=+)
right=0;
}
void E1(void){
if(h-char_ch==+){
h=h-next;
T();
E1();
}
else
if(h-char_ch==#||h-char_ch==))
return;
else right=0;
}
void F() //F-(E)|i
{
if(h-char_ch==i)
h=h-next;
else
if(h-char_ch==()
{
h=h-next;
E();
if(h-char_ch==))
h=h-next;
else
right=0;
}
else
right=0;
}
void main()
{
printf(\n************************* 表达式语法分析器 ***************************\n);
printf(\n\n * 简单表达式文法:\n);
printf( E-E+T|T\n T-T*F|F\n F-(E)|i\n);
printf(\n请输入要判别的表达式(包含字符:i + ( ) *):\n);
right=1;
h=(struct Lchar *)malloc(sizeof(Lchar));
h-next=NULL;
p=h;
do{
ch=getchar();
putchar(ch);
if(ch==i||ch==+||ch==*||ch==(||ch==)||ch==#){
temp=(struct Lchar *)malloc(sizeof(Lchar));
temp-next=NULL;
temp-char_ch=ch;
h-next=temp;
h=h-next;
}
else
{
temp=p-next;
printf(\n输入字符错误(或未输入#)!请重新输入!:\n);
for(;;)
{
if (temp!=NULL)
printf(%c,temp-char_ch);
else break;
temp=temp-next;
}
}
}while(ch!=#);
p=p-next;
h=p;
E();
if(h-char_ch==#righ
文档评论(0)