




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
网工二班 陈衍席 1205110125编译原理实验2 语法分析(2课时)实验目的:理解自上而下分析法的基本思想,理解递归下降分析法的基本思路,掌握构造递归下降子程序的方法。实验内容:运用递归下降子程序法,实现整数四则运算表达式的语法分析程序。实验要求:编写程序,上机调试和测试,纪录调试和测试情况,结合程序进行分析。实验环境:Visual C+ 6.0或以上版本,Windows XP或以上版本,微软汇编工具(在Software子目录下)。实现要点与提示:需要实现的语法分析程序的功能是,接受一个表达式,分析该表达式,并根据输入正确与否给出相应信息。测试时,如果输入的表达式分析正确,则输出表示分析正确的信息;否则,输出表示分析错误的信息。实验代码:#include #include #include char prog100,ch,token8;int p=0,syn,n,i;char *keyword6=begin,then,if,while,do,end;void scaner();void Irparse();void statement();void expression_r();void term();void factor();void main() int select=-1; p=0; printf(please input sentence, end of # !n); do ch=getchar(); progp+=ch; while(ch!=#); p=0; printf(请输入1 或 2 n 1.词法分析n 2.语法分析n); scanf(%d,&select); if(select=1) do scaner(); switch(syn) case -1:printf(词法分析 出错n);break; default :printf(n,syn,token);break; while(syn!=0); printf(词法分析 成功n); else if(select=2) scaner(); if(syn=1) Irparse();/begin else printf(语法分析出错! 请检查begin关键字n);return; if(syn=6)/end scaner(); if(syn=0) printf(恭喜 语法分析 成功n); else printf(语法分析出错! 请检查是否缺少#n); elseprintf(语法分析出错! 请检查是否缺少endn); getchar(); void scaner() for(n=0;n=a&ch=A&ch=a&ch=a&ch=0&ch=9); syn=10; for(n=0;n=0&ch=0&ch=9); syn=11; return; else /ch=progp+; switch(ch) case +:syn=13;token0=ch;break; case -:syn=14;token0=ch;break; case *:syn=15;token0=ch;break; case /:syn=16;token0=ch;break; case :syn=17;token0=ch; ch=progp+; if(ch=)token1=ch;syn+; else p-; break; case )token1=ch;syn+; else if(ch=)token1=ch;syn=syn+2; else p-; break; case :syn=23;token0=ch; ch=progp+; if(ch=)token1=ch;syn+; else p-; break; case =:syn=25;token0=ch;break; case ;:syn=26;token0=ch;break; case (:syn=27;token0=ch;break; case ):syn=28;token0=ch;break; case #:syn=0;token0=ch;break; default: printf(词法分析出错! 请检查是否输入非法字符n);syn=-1;break; /return; void Irparse() scaner(); statement(); while(syn=26)/; scaner(); statement(); void statement() if(syn=10) scaner(); if(syn=18) scaner(); expression_r(); else printf(语法分析出错! 请检查表达式是否正确n);return; else printf(语法分析出错! 请检查语句是否正确n);return; void expression_r() term(); while(syn=13|syn=14)/+ - scaner(); term(); void term() factor(); while(syn=15|syn=16)/* / scaner(); factor(); void factor() if(syn=10|syn=11) scaner(); else if(syn=27) scaner(); expression_r(); if(syn=28) scaner(); else printf(语法分析出错! 请检查是否缺少)n);return; else printf(语法分析出错! 请检查是
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024四川长虹模塑科技有限公司招聘塑压辅助工等岗位1084人笔试参考题库附带答案详解
- 九年级数学下册 第27章 圆27.2 与圆有关的位置关系3切线第2课时 切线长定理与三角形的内切圆教学设计 (新版)华东师大版
- 中考专题之勾画隐圆,破解最值教学设计 2023-2024学年北师大版数学九年级下册
- 2024四川省水电投资经营集团有限公司公开选聘所属公司财务总监5人笔试参考题库附带答案详解
- 专题03 情境补写考点(教案)2025年新高考语文一轮复习考点满分宝典 学案
- 九年级数学上册 第23章 图形的相似23.6 图形与坐标 2图形的交换与坐标教学设计 (新版)华东师大版
- 55018《计算机控制技术(第2版)》于海生版本教学大纲
- 化学九年级上册第1节 构成物质的基本微粒教案设计
- 人教部编版七年级上册第二单元 夏商周时期:早期国家的产生与社会变革第五课 青铜器与甲骨文教学设计
- 人教部编版七年级上册第七课 战国时期的社会变化教学设计
- 水资源利用知到章节答案智慧树2023年西安理工大学
- 名著导读 西游记
- 静脉给药错误演练脚本
- IE动作MOD法培训资料
- 一汽解放维修手册说明书
- 禽流感人流感人间禽流感培训课件
- MT 191-1989煤矿井下用橡胶管安全性能检验规范
- JJF 1319-2011傅立叶变换红外光谱仪校准规范
- GB/T 4857.4-2008包装运输包装件基本试验第4部分:采用压力试验机进行的抗压和堆码试验方法
- GB/T 25174-2010饲料添加剂4,7-二羟基异黄酮
- GB/T 17421.2-2000机床检验通则第2部分:数控轴线的定位精度和重复定位精度的确定
评论
0/150
提交评论