词法分析器实验报告参考模板_第1页
词法分析器实验报告参考模板_第2页
词法分析器实验报告参考模板_第3页
词法分析器实验报告参考模板_第4页
词法分析器实验报告参考模板_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、实验报告实验题目:词法分析器 院系班级:计科系0901班 姓名学号: 2009210603实验时间:2011-10-21 1 / 7实验目的设计。编制并调试一个词法分析程序,加深对词法分析原理的理解。实验要求设计出一个简单的词法分析程序,能够识别关键字(包含begin、if、end、 while、else、 then)、标识符、数字及数种符号(+、-、*、/、(、)、:、=、:=、#、>、<、<>、<=、>=、;)。返回并打印各类字符所对应的种类编码及该字符所组成的二元组。算法设计流程图源代码 # include <stdio.h> # incl

2、ude <string.h> # include <stdlib.h> # include <ctype.h> typedef struct int num; char *word; WORD; char token255="" char input255; int t=0; int i=0; char gjz610="begin","if","then","while","do","end" char ch; WORD

3、* start() WORD*myword=new WORD; myword->num=1; myword->word="" t=0;ch=inputi;i+;while(ch=' '|ch=10)ch=inputi; i+;if (isalpha(ch) while(isalpha(ch)|isdigit(ch) tokent=ch; t+; tokent='0' ch=inputi; i+; i-; int n=0; while(n<=6) if(!strcmp(token,gjzn) myword->num=n+

4、1; myword->word=token; return myword; n+; /关键字 myword->num=10; myword->word=token; return(myword);/标识符else if(isdigit(ch) while (isdigit(ch) tokent=ch; t+; tokent='0' ch=inputi; i+; i-; myword->num=11; myword->word=token; return(myword); /数字elseswitch(ch) case'+':mywor

5、d->num=13; myword->word="+" return(myword);break; case'-':myword->num=14; myword->word="-" return(myword);break; case'*':myword->num=15; myword->word="*" return(myword);break; case'/':myword->num=16; myword->word="/&q

6、uot; return(myword);break; case'<':ch=inputi; i+; if(ch='>') myword->num=21; myword->word="<>" return(myword); else if (ch='=') myword->num=22; myword->word="<=" return(myword); i-; myword->num=20; myword->word="<&q

7、uot; return(myword);break; case'>':ch=inputi; i+; if(ch='=') myword->num=24; myword->word=">=" return(myword); i-; myword->num=23; myword->word=">" return(myword);break; case':':ch=inputi; i+; if (ch='=') myword->num=18; myw

8、ord->word=":=" return(myword); i-; myword->num=17; myword->word=":" return(myword); break; case'':myword->num=26; myword->word="" return(myword);break; case'(':myword->num=27; myword->word="(" return(myword);break; case'

9、;)':myword->num=28; myword->word=")" return(myword);break; case'=':myword->num=27; myword->word="=" return(myword);break; case'#':myword->num=0; myword->word="#"break; case'0':myword->num=1000; myword->word="OVER"break; default: myword->num=-1; myword->word="error" return(myword);break;/符号 void main() WORD* newword=new WORD; printf("input your words:(end with #)n"); scanf("%#s",input); while(newword->num!=1000) newword=start();pr

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论