算符优先实验报告

算符优先实验报告

ID:35234648

大小:116.45 KB

页数:9页

时间:2019-03-22

算符优先实验报告_第1页
算符优先实验报告_第2页
算符优先实验报告_第3页
算符优先实验报告_第4页
算符优先实验报告_第5页
资源描述:

《算符优先实验报告》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、南华大学计算机科学与技术学院实验报告(2011~2012学年度第二学期)课程名称程序设计与编译实验名称算符优先姓名王郑朋学号20104030337专业电气信息类班级1003地点8教教师曹军9一.实验目的设计编写并调试一个算符优先程序,掌握算符优先分析法的原理;二.实验要求对下述描述算符表达式的算符优先文法G[E],给出算符优先分析的实验结果。E->E+T

2、E-T

3、TT->T*F

4、T/F

5、FF->(E)

6、i三.实验代码#include#include#include

7、e.h>#includeusingnamespacestd;constintmaxsize=100;//为数组str[]、in[]分配的最大存储空间constintlength=100;//为数组array[]分配的最大存储空间classstack{private:intsize;//size为当前数组array[]的大小chararray[length];//用于存储读入的字符public:stack(){size=0;//数组array[]的初始长度为0}voidpush(charch){

8、if(size=0){for(inti=0;i

9、intpos)//判断大小是否合法{if(pos>=0&&pos

10、数字或小写字母{return(ch>='0'&&ch<='9'

11、

12、ch>='a'&&ch<='z');}intgetrank(charch1,charch2)//根据算符优先分析矩阵设置读入优先次序{9//0表示等于,1表示大于,-1表示小于,2表示没有优先关系if(isnumch(ch1))ch1='i';if(isnumch(ch2))ch2='i';if(ch1=='+'

13、

14、ch1=='-'){if(ch2=='+'

15、

16、ch2=='#'

17、

18、ch2==')'

19、

20、ch2=='-')return1;elseret

21、urn-1;}if(ch1=='*'

22、

23、ch1=='/'){if(ch2=='('

24、

25、ch2=='i')return-1;elsereturn1;}if(ch1=='('){if(ch2==')')return0;elseif(ch2=='#')return2;elsereturn-1;}if(ch1=='i'

26、

27、ch1==')'){if(ch2=='i'

28、

29、ch2=='(')return2;elsereturn1;}if(ch1=='#'){if(ch2=='#')9return0;elseif(ch2==')

30、')return2;elsereturn-1;}return2;}intisvt(charch)//区别参加规约的资格{if(ch>='a'&&ch<='z')return1;if(ch>='('&&ch<='+')return1;if(ch=='#')return1;if(ch=='/')return1;if(ch=='-')return1;if(ch>='0'&&ch<='9')return1;return0;}/****************主函数**************/intmain(){char

31、juzhen[9][9]={'','+','-','*','/','(',')','i','#','+','>','>','<','<','<','>','<','>','-','>','>','<','<','<','>','<','>','*','>','>','>','>','<','>','<','>','/','>','>','>','>','<','>','<

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。