版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- (2026年)食品安全事故处置管理制度
- 2026年中国工商银行(山东分行)人员招聘笔试参考试题及答案详解
- 2026年解放军第307医院医护人员招聘考试参考题库及答案详解
- 2026年上海交通大学医学院附属仁济医院医护人员招聘考试参考试题及答案详解
- 2026年济南施尔明眼科医院医护人员招聘考试参考试题及答案详解
- 2026年辽油宝石花医院医护人员招聘笔试参考题库及答案详解
- 2026年武汉大学人民医院东院医护人员招聘笔试备考题库及答案详解
- 第10课+马克思主义的诞生和国际工人运动的发展-中职《世界历史》期末背诵清单(高教版2023版)
- 2026年中国中医科学研究院广安门医院医护人员招聘笔试备考题库及答案详解
- 2026年井冈山大学附属医院医护人员招聘笔试参考题库及答案详解
- 2024-2025学年人教版(2024)初中英语七年级下册(全册)知识点归纳
- 《液位传感器》课件
- 内科学(呼吸-循环-消化)知到智慧树章节测试课后答案2024年秋温州医科大学
- 2024年北京市高考物理试卷(含答案逐题解析)
- CHT 4020-2018 管线制图技术规范
- (2024年)《工伤保险培训》ppt课件完整版
- 2024-2025年上海中考英语真题及答案解析
- 办公家具生产设备清单
- 赋能:打造应对不确定性的敏捷团队
- 工业机器人技术与应用PPT完整全套教学课件
- dd5e人物卡可填充格式角色卡夜版
评论
0/150
提交评论