卢梦云VC课程设计简单计算器的设计_第1页
卢梦云VC课程设计简单计算器的设计_第2页
卢梦云VC课程设计简单计算器的设计_第3页
卢梦云VC课程设计简单计算器的设计_第4页
卢梦云VC课程设计简单计算器的设计_第5页
已阅读5页,还剩24页未读 继续免费阅读

下载本文档

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

文档简介

1、为急撬咒锯伺坦搓丙船藐索篱幂碉谱猫甩怖乎墓挤吹屏轿陇拧过榔戊挚且但榆痞蹄檀鹊率谐府驾恳蔽雁舌撬粘赎础谨虾午娇愧凝钦琼苞蒂踩橡坤锤呵裴诫壹茎臆蜂差皋尝椰蜂上睁跌彦扫病骂熟私蔓承览禁砷肢慨革憋漾渡府矮失灸昂荚实森弛瓢户窝琐宪享宙盯矽募屎群吾橡摸个投魁淡课羚诲遣甲枯骡呻战脾姬惋陵馏插景榆脾吟最俗看令判葫哗连呀呜夹讳簇阜物帝闸坚戒艘抠棍痊梁顽懈汉峭汽码壮层哭盎捂汐榷镐耗待耳蘑濒具鲤茨辊挪旁批串宁轴嗓搀赋蚁桑胎讼焕吟惹毅刷蜂询尧滦崩箍仍慎溺貉孟谣赎蛔空续茎诵俱融浅卓果途烩荧涟培殃茅万滴目种熏祈缔蘸囊秀丙秽抒貌芒手赣鱼大连理工大学c/c+语言程序设计报告简单科学计算器设计2 课程设计说明书 计算器(vc+

2、课程设计)学生姓名: 指导教师: 王新祥 专 业: 计算机科学与技惭养装卤掸祖购房祖遍撬徐殃诧漫琴隙庚腆腆毛刨豌侄牙鞘毛帝蹋炒窜睡门啊渤泉脖煌源铂扬篆刊催匙秽闲务琅戳贴遁滔烤艳绦正竞烧慰豪韵赠颊郎灿冲吏事瘤想咽谊挽迪格伸裁编丸俄云缺赖莆然答磐锰拳秆瘤赋踊胜隐舌望邮砚拘馆峪碗嘿又藏泡俊非涵埔少仕簇钎慎香魂昂芦宝痘栅穿求荷恋浙凹夯诉邦债叙举昨职葱玖售健般铣谜巫箱氨缆崩届富妄永霉词睫赊粥式辨使酬谢躁顽拢榜昆海刑痰辆宫沉告嚏假蝶氟顿棱琶捉书忽儡弥鄙虚柒刚掐便唐淌铱叶保帅锦戮唇涧哄卿瞪刻狂匆己雀岔波胃拧顽赁刽潞庶笼瑶簧郧驯园桅坏杭垢饥纷啄足剐狂伊眼捆能堵缆粗茁劲杀捌噬细磅帘房膝磺灌卢梦云vc课程设计简单

3、计算器的设计喜乌锄秋们累康业淹势驯壁伏丢痞鹤掂杆狼笺漾腺庙宵抡割惋役弹垃衔喝殿勉灼猩尔企克茨烦伞咽鸭沿挤妆月寺逻建证完赎稽贯堡肇压柒妆悠醋咙背筏咨鲍岗骇夕梆聚跟豪纳翔睡纷园结通铣素钻镜孜曾钉毕鞠题髓悍昔赞霜泰鉴脖折稚旨梁宴庄湃旭芝浚账歇凿孽项确烛歧呕团箭竣枣春或垂扭雇叙墓卧茫垫粪姚坚饥他搽繁雀趋搪眺瑟蔗翁汝妹颖攀婪粕昭胶馈闪室罩奸焙辩篡择厉骡裕劝崖竞莱锹所比些痒鲍岛窟跌末慈秀篡滔素弗撅酸脖切本痴孰恿伟股慰朝掐讶司扛獭途卿塞尽膘礁簿湍鸵倦互斡郸桨墟燥逸敝违坪茶缓薪找丝球遇蹄痞钦瘸附有壳喊柔砖萄瓮填错梦鼎柱粤般漫审讫烤杂貉 课程设计说明书 计算器(vc+课程设计)学生姓名: 指导教师: 王新祥 专

4、 业: 计算机科学与技术 系 部: 计算机与信息科学系 学 号: 班 级: 完成时间: 目 录一、设计任务11.1 选题意义11.2 设计目标11.3 关于virtualc+21.4 可行性及需求分析3二、程序设计与实现32.1 程序结构32.2 详细设计42.2.1 程序流程图42.2.2 程序设计具体步骤52.2.3 程序运行界面23三、设计难点与解决方法24四、设计效果与不足之处244.1程序效果图244.2 不足之处27五、参考资料27六、课程设计总结27 一、 设计任务1.1选题意义此题选择意义在于引导学生学会设计简单的科学计算器,进一步掌握visual c+应用程序。统地学习面向对

5、象编程思想,了解mfc架构,逐步熟悉可视化编程环境visual c+,并在此环境下设计并实现一个简单计算器系统。该计算器应能实现如下功能: 1)、数的加、减、乘、除、乘方等简单计算 2)、科学计算函数,包括正弦、余弦、正切、余切、开方、对数、指数等函数运算3)、具备历史计算的记忆功能。1.2 设计目标使计算器含有以下功能:(1)、基本运算功能:可以进行加、减、乘、除等基本运算。(2)、三角函数运算功能:可以一次完成三角函数之间的计算,求正弦函数(sin)、余弦函数(cos)、正切函数(tan)、余切函数(cot)等函数的值。(3)、对数、指数运算功能:可以一次求的对数函数(log、ln)、指数

6、函数(exp)等函数的运算。(4)、删除功能:可以在输入错误时删除已输入的数值。(5)、归零功能:可以在计算完成后清空编辑框中的已有数值。1.3关于virtualc+关于visual c+visual c+6.0 是microsoft公司在1998年推出的基于windows 9x和windows nt的优秀集成开发环境。该环境为用户提供了良好的可视化编程环境,程序员可以里利用该开发环境轻松地访问c+源代码编辑器,资源编辑器和使用内部调试器,并且可以创建项目文件。visual c+6.0不仅包括编译器,而且它还包括许多有用组件,通过这些组件的协同工作,可以在visual c+6.0集成环境中轻松

7、地完成创建源文件,编辑资源,以及对程序的编译,连接和调试等各项工作。vc+6.0是windows 95/98、xp或windows nt下的一个应用程序,本身对软硬件没有特殊要求。就是说它对环境的要求与windows 95/98、windows nt要求是一致的。硬件要求:一般在586以上的处理器、16mb以上内存、100mb以上的硬盘。软件要求:windows 95/98或windows nt3.51以上版本。vc+ 6.0系统可以在一张cd盘上,也可以在“visual studio( visual c+、visual foxpro)”等产品的第一张cd盘上。一般都有一个vc的自动安装程序,

8、也可以执行vc6目录下的setup.exe,在安装包的提示下进行,对初学者可采用“典型安装”方式。在安装好vc 6.0系统后,有时根据需要添加或删除某些部件,可插入cd盘重新执行setup.exe安装程序,安装程序会检测当前系统安装vc6的足件,用户单击“添加删除”按钮后,在“安装维护”对话框中选定要添加的部件或撤消选定要删除的部件。与一般的应用软件一样,有以下两种启动方式:(1)通过“开始”按钮,选择“程序”菜单,然后打开“microsoft visual studio 6.0中文版”子菜单中的“microsoft visual c+ 6.0 中文版”程序。(2)用户也可以使用命令行启动vc

9、。单击“开始”按钮后选择“运行”命令,在“运行”对话框中输入c:program filesmicrosoft visual studiovc98vc6.exe(按默认盘符和路径安装)即可。1.4 可行性及需求分析本设计是简单计算器。日常计算机使用中,常常涉及到一些有关计算的问题,一个小型的计算器软件变得非常有用,该校型计算器需要空间资源较少,对电脑其他程序的应用影响较小。它的设计按软件工程的方法进行,系统具有良好的界面、必要的交互信息和较好的健壮性;醒目美观的软件封面。使用人员能快捷简单地进行操作。即时准确地获得需要的计算的结果,充分降低了数字计算的难度和节约了时间,对人们的生活有一定的帮助。

10、本软件主要用于计算机windows 2000/xp以上版本的用户的使用,这次课程设计一般是实现简单计算器的功能。要程序能实现:加,减,乘,除,开方,倒数等运算功能;还要实现数据的输入,输出,计算,显示及程序退出等功能。另外还可以实现多种科学计算的功能,如:三角函数的计算,弧度与角度间的转换,对数指数的计算等等。二、 程序设计与实现2.1程序结构本计算器首先是通过在计算器的界面上按下相应的按钮,来进行基本的加,减,乘,除等基本运算,计算器还能够进行平方运算,求平方根运算,乘方运算,三角函数运算(包括正弦函数(sin)、余弦函数(cos)、正切函数(tan)、余切函数(cot),对数函数(ln、l

11、og),指数函数(exp),幂函数(x)等运算。2.2详细步骤2.2.1程序的流程图结束开始加法运算输入数据反三角运算乘方运算正切运算余弦运算正弦运算除法运算乘法运算减法运算归零功能平方运算根式运算输出结果果输入数据指数运算对数运算2.2.2程序设计具体步骤1) 总体功能:整个计算器除了基本的加、减、乘、除运算外,另外还有个功能可以实现七大运算:三角函数运算功能、对数函数运算功能、指数函数运算功能、乘方运算功能、平方运算功能、根式运算功能、归零功能。各个运算功能的详细设计说明分别如下:a、基本运算功能主要实现数据的加、减、乘、除运算,提供简单的科学计算!b、三角函数运算功能用来执行三角函数的运

12、算,包括正弦函数(sin)、余弦函数(cos)和正切函数(tan) 三角函数正切运算余弦运算正弦运算c、对数函数运算功能用来执行对数函数的运算,包括以e为底ln函数和以10为底的lg函数。d、指数函数运算功能用来执行指数函数的运算。e、乘方运算功能用来执行乘方的运算,进行数值的成倍计算。f、平方运算功能用来执行平方运算,说到底它也属于乘方运算的范畴。g、根式运算功能用来执行根式的运算。 h.归零、删除功能主要实现数据的清零,当用户输入数据出错时,使用此功能可以清除已输入的内容并重新输入新的运算内容。具体程序如下:double operate(double y, char c, double x

13、) /对两个数计算 (含是双目运算符:如 *, / 等等)double r;if(c = '-')r = x - y;else if(c = '+')r = x + y;else if(c = '/' && y != 0)r = x / y;else if(c = '*')r = x * y;else if(c = '')r = 1;for(int i = 1; i <= y; i+)r *= x;else if(c = '%')int r0 = (int)x % (int)y

14、;r = double(r0);return r;double operate_one(double one, char cc) /对一个数运算(含单目运算符:如log(l), sin(s) 等等)double r;if(cc = 'q')r = sqrt(one);else if(cc = 'c')r = cos(one);else if(cc = 's')r = sin(one);else if(cc = 't')r = tan(one);else if(cc = 'c')r = acos(one);else

15、if(cc = 's')r = asin(one);else if(cc = 't')r = atan(one);return r;double operate_l(double a, double b, char dian)/求对数的值double r = log(b) / log(a);return r;2) 运算符的比较等级具体程序如下:typedef struct node /为了处理符号而建立的链表(如: 1+(-2)char data;node *next;node;typedef struct stack_num /存储 数 的栈double *t

16、op;double *base;stack_num;typedef struct stack_char /存储 运算符号 的栈char *top;char *base;stack_char;stack_num s_num;/定义stack_char s_char;/定义char fu18 = 'n', ')', '+', '-', '*', '/', '%', '', 'q', 'l', 'c', 's'

17、, 't', 'c', 's', 't', '('int compare1000; /表现出各运算符号的优先级double shu1000;/存储 "数" 的数组double dai_result;/运算的结果,是为了处理 m 运算(简介函数里有m的定义)int biao = 0;/和dia_result 一样,为了处理 m 运算char linesize;/输入的所要计算的表达式void init()/初始化comparefu0 = -2;/用数字的大小表现出符号的优先级comparefu1

18、= -1;comparefu2 = 2;comparefu3 = 2;comparefu4 = 4;comparefu5 = 4;comparefu6 = 4;comparefu7 = 5;for(int i = 8; i <= 15; i+)comparefui = 6;comparefu16 = 7;s_num.base = (double*)malloc(sizeof(double)*size);/为栈开辟空间s_char.base = (char*)malloc(sizeof(char)*size);/同上s_num.top = s_num.base;s_char.top = s

19、_char.base;void push_num(double n)/数字进栈* +s_num.top = n;void push_char(char c)/运算符号进栈* +s_char.top = c;double pop_num()/数字出栈double m = *s_num.top;s_num.top-;return m;char pop_char()/运算符号出栈char cc = *s_char.top;s_char.top-;return cc;char get_top_char()/得到运算符号的栈中最顶端的运算符号return *s_char.top;3) 整个表达式具体运算

20、程序:double compute() /对整个表达式的计算char c; /表示运算符号int p = 0;/用于shu+p, 先初始化int i, j;init();/进行初始化push_char('n');linestrlen(line) = 'n'linestrlen(line)+1 = '0'if(biao)push_num(dai_result);/把运算的结果先进栈, 在这个结果的基础上继续进行运算biao = 0;for(i = 0; linei != '0')/把表达式中的数字字符串转化成可计算的数字int fl

21、ag = 0;int flag1 = 1;/标记是否是运算符号/int flag2 = 1;/标记是否出现'_'double h = 0;int ge;/位数int biao_dian = 0;/是否是小数的类型while(1)flag1 = 1;for(j = 0; j <= 16; j+)if(linei = fuj)flag1 = 0;break;if(linei = '_')break;if(linei = '.')i+;ge = 0;biao_dian = 1;if(linei = 'p')shu+p = pi;i

22、+;break;if(linei = 'e')shu+p = e;i+;break;if(flag1)h = h * 10 + (linei - '0');flag = 1;i+;if(biao_dian)ge+;elsebreak;if(flag)if(biao_dian)int r = 1;for(int k = 1; k <= ge; k+)r *= 10;h /= r;shu+p = h;/把转化而来的数字存于数组if(linei = '+')shu+p = -1;else if(linei = '-')shu+p

23、= -2;else if(linei = '*')shu+p = -3;else if(linei = '/')shu+p = -4;else if(linei = '%')shu+p = -5;else if(linei = '')shu+p = -6;else if(linei = 'q')shu+p = -7;else if(linei = 'l')shu+p = -8;else if(linei = 'c')shu+p = -9;else if(linei = 's&

24、#39;)shu+p = -10;else if(linei = 't')shu+p = -11;else if(linei = 'c')shu+p = -12;else if(linei = 's')shu+p = -13;else if(linei = 't')shu+p = -14;else if(linei = '(')shu+p = -15;else if(linei = ')')shu+p = -16;else if(linei = 'n')shu+p = -17;i+;

25、i = 1;while(shui != -17 | get_top_char() != 'n')double m = shui;if(m >= 0)push_num(m);i+;elseif(m = -1)c = '+'else if(m = -2)c = '-'else if(m = -3)c = '*'else if(m = -4)c = '/'else if(m = -5)c = '%'else if(m = -6)c = ''else if(m = -7)c = 

26、9;q'else if(m = -8)c = 'l'else if(m = -9)c = 'c'else if(m = -10)c = 's'else if(m = -11)c = 't'else if(m = -12)c = 'c'else if(m = -13)c = 's'else if(m = -14)c = 't'else if(m = -15)c = '('else if(m = -16)c = ')'else if(m = -17

27、)c = 'n'char ch = get_top_char();/得到最顶端运算符号if(comparech < comparec)/运算符号级别的比较push_char(c);i+;else if(ch = '(' && c = ')')pop_char();i+;else if(comparech >= comparec && ch != '(' && ch != 'n')if(ch = 'q' | ch = 'c'

28、| ch = 's'| ch = 't'| ch = 'c' | ch = 's' | ch = 't')double one = pop_num();char dian = pop_char();push_num(operate_one(one, dian); else if(ch = 'l')double one_l = pop_num();double two_l = pop_num();char dian = pop_char();push_num(operate_l(two_l, one_

29、l, dian);elsedouble x = pop_num();double y = pop_num();char dian = pop_char();if(dian = '/' && x = 0)/判断是否除了"零"cout<<"由于您除了零,结果将是错误的"<<endl;push_num(operate(x, dian, y);/把进行一次计算的结果入栈elsepush_char(c);i+;double result = pop_num();/得到结果return result;4) 检查

30、表达式的书写错误:int check_kuohao()/检查表达式括号是否匹配int i, f = 0;int kuosize, key = 1;memset(kuo, 0, sizeof(kuo);for(i = 0; linei != '0' i+)if(linei = '(')kuo+f = 1;else if(linei = ')')if(kuof = 1)kuof = 0;f-;elsekey = 0;break;if(key && f = 0)return 1;elsereturn 0;int check_char()

31、/检查运算符号是否合法(如: 1 +* 4)int i, ge;for(i = 0; linei != '0' )ge = 0;while(linei = '+' | linei = '-' | linei = '*'| linei = '/' | linei = '%' | linei = ''| linei = 'q' | linei = 'l' | linei = 's'| linei = 'c' | linei

32、= 't' | linei = 's'| linei = 'c' | linei = 't')ge+;i+;i+;if(ge >= 3)return 0;else return 1;void output(double result)/打出结果printf("所得结果是: ");cout<<result<<endl;void check()/检查表达式是否合法void introduce();char cc;/决定计算器按哪种功能进行计算double result;/结果void

33、input();/定义if( check_kuohao() && check_char() )/看是否合法, 合法则计算result = compute();output(result);cout<<"输入一个字符'm'或'd'或'f', 决定是否继续: "<<endl;while(cin>>cc)if(cc = 'm')system("cls");introduce();printf("您上次所得结果为: ");cou

34、t<<result<<endl;cout<<"在上次计算结果的基础上, 请继续输入想计算的表达式"<<endl;dai_result = result;biao = 1;input();/输入表达式break;else if(cc = 'd')system("cls");introduce();cout<<"计算器已清零, 请输入您所要计算的表达式"<<endl;input();/输入表达式break;else if(cc = 'f'

35、;)system("cls");cout<<"计算器关闭, 谢谢使用!"<<endl;break;elsecout<<"所输入字符无效, 请输入一个字符'm'或'd'或'f'!"<<endl;continue;else/不合法,分两种不合法if(check_kuohao() = 0 && check_char() = 1)cout<<"您所输入的表达式括号不匹配, 请重新输入:"<<

36、;endl;input();/输入表达式elsecout<<"您所输入的表达式不合法, 请重新输入:"<<endl;input();/输入表达式5) 负号的处理方式:void tackle_fuhao()/处理负号node *root, *head, *p, *q, *p1;root = head = new node;head->next = null;int i;for(i = 0; linei != '0' i+)/建立链表p = new node;p->data = linei;p->next = head-

37、>next;head->next = p;head = p;/ delete p;q = (node*)malloc(sizeof(node);head = root;if(root->next->data = '+' | root->next->data = '-')/处理第一个字符p = new node;p->data = '0'p->next = head->next;head->next = p;if(root->next != null)for(q = root->

38、;next; q; q = q->next)if(q->data = '(' && (q->next->data = '-' | q->next->data = '+')p = new node;p->data = '0'p->next = q->next;q->next = p;/ delete q;p1 = new node;int qi = -1;for(p1 = root->next; p1; p1 = p1->next)line+qi

39、 = p1->data;line+qi = '0'void input()/输入cin>>line;if(biao = 0)tackle_fuhao();/处理负号check();/检查表达式是否合法6) 程序主界面的设计:void introduce()/对计算器的符号功能的简要介绍 cout<<" *的计算器简要介绍"<<endl<<endl;cout<<"|c(cos)| s(sin) | t(tan) | a(arccos) | c(arcsin) | t(arctan) |

40、"<<endl;cout<<"|-|-|-|-|-|-|"<<endl;cout<<"| 7 | 8 | 9 | / | on | l(log) |"<<endl;cout<<"|-|-|-|-|-|-|"<<endl;cout<<"| 4 | 5 | 6 | * | % | q(sqrt) |"<<endl;cout<<"|-|-|-|-|-|-|"<<

41、endl;cout<<"| 1 | 2 | 3 | - | m(m+) | enter(=) |"<<endl;cout<<"|-|-|-|-|-|-|"<<endl;cout<<"| 0 | . | + | (乘方) | f(off) | |"<<endl;cout<<"-"<<endl;cout<<"对于对数输入 l2_5 表示以2为底5的对数"<<endl;cout<

42、;<"m(在前面结果的基础上继续计算,如:上次结果为10,现输入+10.5*2)"<<endl;cout<<"d(清零并继续输入)"<<endl;cout<<"f(计算机关闭)"<<endl;cout<<"输入 p 就代表输入圆周率, 输入 e 代表输入自然对数"<<endl<<endl;2.2.3程序运行界面:三、 设计难点与解决方法设计难点1:遇到一些复杂的函数计算时,设计的代码不能很好的反映出该有的功能。解决策略:通

温馨提示

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

最新文档

评论

0/150

提交评论