ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:47.40KB ,
资源ID:24725105      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/24725105.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(算术表达式求值运算实验指导书.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

算术表达式求值运算实验指导书.docx

1、算术表达式求值运算实验指导书实验一 算术表达式求值一、实验目的帮助学生熟练掌握栈的基本操作,并通过用算符优先法对表达式求值的过程深刻领会用栈解决实际问题的基本方法。二、实验内容编写程序实现从键盘终端输入语法正确的算术表达式,计算出表达式的值。为了避免算符的二义性,可以假设表达式中只包含实型正常数运算符包括加、减、乘、除四种基本运算,可以包含圆括号。三、实验仪器微型计算机实验用编程语言:Turbo C 2.0,Borland C 3.0等以上版本四、实验原理1、算术四则运算法则: 先乘除后加减 从左至右 先括号内后括号外 2、方法:对运算符建立优先关系矩阵,按优先关系对表达式进行处理。 算符:运

2、算符和界符。根据法则1:对于两个相邻运算符,乘除优先于加减。 根据法则2:乘除优先级相同,加减优先级相同。相邻两个同级运算符左优先。根据法则3:“(”前面的运算符优先级低于“(”的优先级。“(”的优先级低于右边相邻算符。“)”左边的算符高于“)”的优先级。由于“(”和“)”必须成对出现,令它们的优先性相同。 为了处理的方便,假设表达式以“”开始和结束,输入表达式的一般形式为:#表达式#如: #5.3+4.2*(7.6+4.5)#规定开始的“”的优先性低于所有其它算符,所有其它算符的优先性高于结束的“”。根据假设,表达式开始的“#”和结束的“#”必须成对出现,所以也令它们的优先性相同。对于一个正

3、确的表达式,“)”不可能与“(”相邻,“(”不可能与结束的“#”相邻,开始的“#”不可能与“)”相邻,它们之间没有优先性,程序应具有这种判断能力。根据上面的讨论,可用表1所示的算符优先关系矩阵来描述算符之间的优先关系,其中,用“”表示表达式中前一个算符的优先性高于后一个算符的优先性,用“=0 & strpp=0 & strpp=0 & strpp=0 & strpp=9) /处理实数的小数部分 number=number+(strpp-48)/temp; temp=temp*10; pp+; 七、思考题 1、若表达式中的数据带有正负号的实数字符串该怎样进行转换?2、对于指数形式的实数字符串该怎

4、样进行转换?八、部分函数代码#include#include #include #define PLUS 0#define MINUS 1#define POWER 2#define DIVIDE 3#define LEFTP 4#define RIGHP 5#define STARTEND 6#define DIGIT 7#define POINT 8#define NUM 7#define NO 32767#define STACKSIZE 20/运算符 char a=+,-,*,/,(,),#; /优先关系矩阵,规定:=为0,为1,为-1,空为NO int PriorityTable77

5、= 1, 1,-1,-1,-1, 1, 1, 1, 1,-1,-1,-1, 1, 1, 1, 1, 1, 1,-1, 1, 1, 1, 1, 1, 1,-1, 1, 1, -1,-1,-1,-1,-1, 0, NO, 1, 1, 1, 1,NO, 1, 1, -1,-1,-1,-1,-1,NO, 0 ; int menu(void); /*/ /* 输入表达式函数 */ /*/void InputExpression(char str) int len; printf(Input expression string:n); scanf(%s,str); len=strlen(str); str

6、len=#; strlen+1=0; /*/ /* 确定当前字符类型 */ /*/ /* 若为运算符,则返回运算符在运算符数组中的序号 */ /* 若为数字字符,则返回DIGIT */ /* 若为小数点字符,则返回POINT */ /* 否则为非法字符,返回-1 */ /*/int GetCharType(char ch) int i; for(i=0;i=0 & ch=0 & strpp=0 & strpp=0 & strpp=9) number=number+(strpp-48)/temp; temp=temp*10; pp+; OPNDtopNd=number; topNd+; brea

7、k; case PLUS: /+ case MINUS: /- case POWER: /* case DIVIDE: / (学生自己完成) case LEFTP: /( (学生自己完成) case RIGHP: /) (学生自己完成) case STARTEND: /遇到表达式结束符 (学生自己完成) if(topNd=1) *Result=OPND0; return(1); else return(0); return(1); void main() int num,flag; double result; char str256; str0=0; while(1) num=menu();

8、 switch(num) case 1: /输入表达式 InputExpression(str); flag=0; printf(%sn,str); getchar(); break; case 2: /计算表达式 if(str0=0) printf(Expresson is Empty!); getchar(); break; if(!eccute(str,&result) printf(The expression has error!n); getchar(); else printf(calulation has finished!n); getchar(); flag=1; brea

9、k; case 3: /打印计算结果 if(flag) printf(#%s=%lfn,str,result); getchar(); break; case 4: /退出系统 break; if(num=4) break; int menu(void) int num; clrscr(); printf(%20c1-input expressionn, ); printf(%20c2-calculation expressionn, ); printf(%20c3-print resultn, ); printf(%20c4-Quitn, ); printf( please select 1,2,3,4:); do scanf(%d,&num); while(num4); return(num);

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1