- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理课程设计
实验报告
课 题: 词法分析器
专 业: 计算机科学与技术
班 级: 1班
姓 名: 张新豪
学 号:
指导教师: 许高建
安徽农业大学经济技术学院 2010-11-04 毕
目录
课题、小组成员及分工 。。。。。。。。。。。。。。。。 3
课程设计及要求 。。。。。。。。。。。。。。。。。。。。。。。 3
主要算法描述 。。。。。。。。。。。。。。。。。。。。。。。。 4
运行效果及截图 。。。。。。。。。。。。。。。。。。。。。。。 9
设计小结 。。。。。。。。。。。。。。。。。。。。。。。。。。。。 10
主要参考文献 。。。。。。。。。。。。。。。。。。。。。。。。。 11
07级计算机科学与技术1班
课题、小组成员及分工
课题:c语言语法分析器
小组成员及分工:
张新豪(组长):编写源程序代码
周浩:修改并测试程序及监工。
魏少骞(副组长):提供环境及指导意见。
张强、韩张纯:共同研究发现问题,解决问题。
课程设计及要求
在计算机高速普及的今天,越来越多的高级语言面向了世人,而对于每一种高级语言都配置了一个甚至多个编译程序,因此编译程序就显得尤为重要了,因此本课程设计用c语言编写一个小型的词法分析器以实现词法分析的部分功能。
要求:能够分析出词法的五大类即:标识符、关键字、常量、分间符、运算符;给出一个语句判断是否正确,若出错,指出什么错误。
主要算法描述
#includestdio.h
#includestring.h
#includeconio.h
#includectype.h
void main(){
printf(此程序是编译原理的课程设计--简单的词法分析器\n\n授课教师:许高建\n\n);
printf(温馨提示:\n本语言标识符只能由字母数字组成,并且首元素只能是字母\n\n);
zxh: printf(请输入一条语句:);
char gjz[3]={i,n,t};
char gjz1[4]={c,h,a,r};
char input[1024];
char zf[10];
char bzf1[1024];
char bzf2[1024];
char cl[1024];
gets(input);
int len=strlen(input);
//printf(%d,len);
int i=0,j=0,k=0,l=0;
int a1=0,a2=0,a3=0,a4=0;
//for(int m1=0;m1len;m1++)
//printf(%c,input[m1]);
do{
if(input[i]== ){
j=i;i++;}
else if(input[i]===){
k=i;i++;}
else if(input[i]==+||input[i]==-||input[i]==*||input[i]==/){
l=i;i++;}
else i++;
}while(ilen);
//printf(%d,%d,%d,j,k,l);
int b1=j+1,b2=k+1,b3=l+1;
for(int m=0;mj;m++){
if(input[m]!=gjz[m] input[m]!=gjz1[m]){
printf(输入了非法的关键字);
a1=1;break;
}
else zf[m]=input[m];
}
for(int n=j+1;nk;n++){
if(isalnum(input[n])==0){
printf(\n输入的第一个标识符不合法,只能由字母及数字组成\n);
a2=1;break;
}
else bzf1[n-b1]=input[n];
}
for(int r=k+1;rl;r++){
if(isalnum(input[r])==0){
printf(\n输入的第二个标识符不合法,只能由字母及数字组成\n);
a3=1;break;
}
else bzf2[r-b2]=input[r];
}
for(int s=l+1;slen-1;s++){
if(isdigit(input[s])==0){
printf(\n输入了非数值型常量\n);
a4=1;break;
}
else cl[s-b3]=input[s];
}
您可能关注的文档
- 从金砖银行到亚投行:建立国际经济新秩序中的中国战略.docx
- 共青团的由来.doc
- 华师16秋《国际经济法学》在线作业.doc
- 团刊.docx
- 团徽的相关知识.doc
- 团问答题.doc
- 国际投资法模拟试题(二).doc
- 建立适应中国的世界经济新秩序.doc
- 张新春课件.ppt
- 当今世界主题与国际新秩序.ppt
- 数据仓库:Redshift:Redshift与BI工具集成.docx
- 数据仓库:Redshift:数据仓库原理与设计.docx
- 数据仓库:Snowflake:数据仓库成本控制与Snowflake定价策略.docx
- 大数据基础:大数据概述:大数据处理框架MapReduce.docx
- 实时计算:GoogleDataflow服务架构解析.docx
- 分布式存储系统:HDFS与MapReduce集成教程.docx
- 实时计算:Azure Stream Analytics:数据流窗口与聚合操作.docx
- 实时计算:Kafka Streams:Kafka Streams架构与原理.docx
- 实时计算:Kafka Streams:Kafka Streams连接器开发与使用.docx
- 数据仓库:BigQuery:BigQuery数据分区与索引优化.docx
文档评论(0)