版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 先进技术制造
- 2024人教版八年级英语上册 Unit 6 Plan for Yourself 单元测试题
- 侦察监视技术
- 企鹅英文介绍课件
- 法警面试题及答案
- (中级)收银员职业技能鉴定理论考试浓缩题库(附答案)
- 小学五年级语文上册第一单元单元预习单设计课件
- 小学五年级语文上册第八单元读书方法总结指导课件
- 2026年赤峰市教育局直属学校第二批次通过“绿色通道”引进高层次教师备考题库有完整答案详解
- 2026年北京市平谷区政务服务中心综合工作人员招聘备考题库及答案详解(夺冠系列)
- DRBFM的展开详细解读2
- 四环素的发酵工艺课件
- 中山大学研究生因公临时出国境申报表
- 泥浆护壁钻孔灌注桩的施工
- 征信调研报告3篇
- YY/T 0127.18-2016口腔医疗器械生物学评价第18部分:牙本质屏障细胞毒性试验
- LY/T 2677-2016油茶整形修剪技术规程
- GB/T 8924-2005纤维增强塑料燃烧性能试验方法氧指数法
- GB/T 20969.2-2021特殊环境条件高原机械第2部分:高原对工程机械的要求
- 马克思主义经典著作导读课后练习试题答案与解析搜集
- 快速记忆法训练课程速读课件
评论
0/150
提交评论