数据结构课程设计(算术表达式求值)-计算器(源代码报告)_第1页
数据结构课程设计(算术表达式求值)-计算器(源代码报告)_第2页
数据结构课程设计(算术表达式求值)-计算器(源代码报告)_第3页
数据结构课程设计(算术表达式求值)-计算器(源代码报告)_第4页
数据结构课程设计(算术表达式求值)-计算器(源代码报告)_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、数据结构课程设计(算术表达式求值)-计算器(源代码报 告)高级语言程序设计算术表达式求值课程设计报告1笫一章系统标算术表达式求值系统可以实现实现对算术四则混合运算表达式求值并打印求值过程中运算符栈、操作数栈的变化过程。第二章系统分析开始运行时界面如下:Clear ; EqualCE) J QuitCQ) input an express ion pe key 1 E? to compute你可以输入一个表达式按E对其进行求值。 第三章系统设计开始输出菜单界面,输入表达式确定选C选E选Q是否计算,清除结束,退出求值3第四章系统实现include include include include d

2、efine N 100double numStackN = 0 ;/操作数栈 int numTop;char opStackN : /运算符栈int opTop;void print_num(double strl , int n)int i;printfCAn 操作数栈:n);for(i=0;in;i+)printf (,z%g , strli);void print_op(char str2,int m)int j;printf (n 运算符栈:n);for(j=0;j0)if (str i=, O &str i二9)num=num* 10+str Li-0 ;else if ( k=l&

3、stri二二&(i二二0 op (stri-1) k 二T;elseif (i0&!op(stri-l)&str i!二(&striT !=)5numStacknumTop+=num*k;辻(opTop!=0&numTop!=0)print_num(numStack, numTop);num=0; j二1; k=l;if (opTop=0 |stri=()opStackopTop+=stri:print_op(opStack, opTop); else if (stri=,)while(opTop0&opStack-opTop !二()numStacknumTop-2=result(numSt

4、acknumTop-2,opStackopTop, numStacknumTop-1);辻(opTop!=0&numTop!=0)print_num(numStack, numTop);printop(opStack, opTop);numTop;if (opStackopTopZ !二()return 0;elseif (stri=0&mimTop=0) return 0;while (opTop0&op (str i) O &ch W )stri+=ch;strEi 0f ;menu ();printf (,zinput an expression, press key E to comp

5、uten,z);printf (%s: str);if ( ch=& (i=l I I op (str i2 )11 ch=, 01 &ch=, 9f )numj+二 ch;numj二0,;elsej 二0;辻(ch二二II ch二二c) if(strlen(str)str-i二0,;printf (z,input an expression, press key E to computen,z): printfstr);辻(ch二二|丨 ch二二e) if(compute (str)printf(n=%grT, numStack0);j=0; temp=numStack0;if(temp=1

6、0) k*=10;while(k)num j+ =temp2/k+, 0 ;numj二0 ;temp2=temp2%k;k/=10;temp=temp-(int)temp;if(temp!二0)numj+二.,;numj二0;temp+二0. 0000005;9for (k=6;k0;k)if(temp=0) break;temp*二10;numj+二(int) temp+ O;numj二0;temp二temp-(int)temp;i=0; j=0; str0=0;if(ch=Q : ch=q) printf (z/nare you sure to quit? (Y/N) n);ch=getc

7、h();if (ch= YI ch= y) break;elsemenu ();printf input an expression, press key E to computen,z):printfstr);ch=getch();return 0;10第五章系统测试1. 先输入:3+2*5后按E求值ClearC) I Equal I Quit input an express ion press key E to conpiite3*2*5运算符栈: 鬲乍数栈: 铸符钱: 祺活数栈:3 2 5操作数栈:3 10运鼻符栈:-+=132. 再输入:12/4-5后按E求值Gleau ; EqualCE? ; QuitCQinput an expressionF press key J E* to conpute 12/4-5运算符檢霸数栈:12 4运算符栈:齢数栈:3 5=-23. 再输入Q收获:经过这次课程设计我重新回忆起许多以前学过的知识如:栈字符串等 等。也学习到了一些新的知识如:,g是数值输出时去掉无用的零等等。疑问:如何进行函数运算,如:log, sin等等。第七章参考文献杨升数据结构厦门出版社200

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论