分数计算器设计_第1页
分数计算器设计_第2页
免费预览已结束,剩余15页可下载查看

下载本文档

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

文档简介

1、分数计算器设计黔南民族师范学院计算机科学系姓名:何-_扌旨导老师:_ 任-_学号:1208075-班级:B12计科班日期:2013.12.2_1 1、问题描述定义一个整数类。定义一个分数类,由整数类派生出。能对分数进行各种 计算和输入/ /输出。2 2、功能要求(1 1)定义整数类和分数类。其中,包括构造函数、析 构函数、显示函数等。(2 2)输入/ /输出:对流提取和流插入运算符进行重载。(3 3)计算功能:可进行分数的加、减、乘和除法运算。(4 4)化简功能:将分数化简为最简分数。(5 5)异常处理功能:分数中分母不能为零。(6) 菜单功能:每种功能的操作都是在菜单中进行相 应选择。3 3

2、、问题的解决方案根据系统功能要求,可以将问题解决分为以下步骤:(1)(1) 应用系统分析,建立该系统的功能模块框图以及界面的组织和设计;(2)(2)分析系统中的各个实体及它们之间的关系;成员函数定义Main.objMain.obj分数计算器.obj.objI I_ _ I I* * main.exemain.exe(3 3)根据问题描述,设计系统的类层次;(4 4)完成类层次中各个类的描述;(5 5)完成类中各个成员函数的定义;(6 6)完成系统的应用模块;(7 7)功能调试;(8 8)完成系统总结报告。源代码:/分数计算器h.h:#in cludeclass In teger /整数类pro

3、tected:int fz;主函数int fm;public:Integer(int a=0,int b=1):fz(a),fm(b)Integer()void display();class Fraction:public Integer/分数类,进行计算和输入输出public:Fraction(int a=0,int b=1):Integer(a,b)Fraction operator+(Fraction &c); /重载+运算符(分数与分数)Fraction operator+(int n); /重载+运算符(整数与分数)Fractionoperator-(Fraction&am

4、p;c);/重载-运算符(分数与分数)friend istream& ,Fraction & ); / friendostream& ,Fraction & ); /& operator(istream重载输入流& operator(ostream重载输出流Fraction operator-(intn);/重载-运算符(整数与分数)friend Fraction operator-(int n,Fraction &c);Fractionoperator*(Fraction&c);/重载*运算符(分数与分数)Fraction op

5、erator*(intn);/重载*运算符(整数与分数)Fraction operator/(Fraction &c);/重载/运算符(分数与分数)Fraction operator/(int n); /重载/运算符 (整数与分数)friend Fraction operator/(int n,Fraction &c);Fraction predigest(); /约分函数void display();/实现函数(分数计算器设计)#include#include分数计算器h.hvoid Integer:display ()coutendl;cout分数计算器 - endlend

6、l;cout请选择功能:endl;cout1分数与整数的四则运算。endlendl;cout2整数与分数的四则运算。endlendl;cout3分数与分数的四则运算。endlendl;cout0输入0退出。endlendl;Fraction Fraction:predigest()/int n,d,t,sign=1;Fraction temp;if(fz0 & fm0 & fm0)fm=-fm; sign=-1;if(fz0)fz=-fz; sign=-1;n=fz; d=fm;int r;if(nd) /辗转相除,求分子n与分母d的最大公约数t=n;n=d;d=t;r=n%d

7、;while(r!=0)n=d;d=r; /d为最大公约数r=n%d;temp.fz=sign*(fz/d);temp.fm=fm/d;return temp;Fraction Fraction:operator+(Fraction &c)/重 载两个分数的加法运算符Fraction temp;temp.fz=fz*c.fm+fm*c.fz;temp.fm=fm*c.fm;return temp;Fraction Fraction:operator+(int n)/和整数的加法运算Fraction temp;temp.fz=fm*n+fz;temp.fm=fm;return temp;

8、Fraction operator-(int n,Fraction &c)Fraction temp;temp.fz=c.fm*n-c.fz ;temp.fm=c.fm;return temp;重载分数Fraction Fraction:operator-(int n)载分数减整数的减法运算符Fraction temp; temp.fz=fz-fm*n; temp.fm=fm;return temp;Fraction Fraction:operator-(Fraction/重载两个分数的减法运算符Fraction temp ;temp.fz =fz*c.fm -fm*c.fz;temp

9、.fm =fm*c.fm;return temp;Fraction Fraction:operator*(Fraction &c) /重载两个分数的乘法运算符Fraction temp; temp.fz=fz*c.fz;temp.fm=fm*c.fm;return temp;Fraction Fraction:operator *(int n)载分数与整数的乘法运算符Fraction temp; temp.fz=fz*n; temp.fm=fm;/重&c)/重return temp;Fraction Fraction:operator/(Fraction &c) /重载

10、两个分数的除法运算符Fraction temp;temp.fz=fz*c.fm;temp.fm=fm*c.fz;return temp;Fraction Fraction:operator/(int n)/重载分数除以整数的除法运算符Fraction temp; temp.fz=fz; temp.fm=fm*n;return temp;Fraction operator /(int n,Fraction &c)Fraction temp;temp.fz =n*c.fm ;temp.fm =c.fz ;return temp;ostream& operator(ostream &

11、amp;output,Fraction &t) /重载输出运算符,输出分数int a,b,c;a=t.fz;b=t.fm;if(a=0|b=0) /当分子,或者分 母为0时,输出0cout0;if(b=1) /当分母为1时, 输出分子coutb&b!=1) /判断分数为假分数c=a/b; a=a%b; coutc; if(a!=0) cout又a/b;if(ab&b!=1) /当分数为负时,判 断为假分数c=-a/b; a=-a%b; c=-c; cout=c;if(a!=0) cout又a/bendl;cout0&t.fzt.fm & t.fm!=0&

12、amp;t.fm!=1)/判断为真分数outputt.fz/t.fm;if(t.fz0 & -t.fzt.fm &t.fm!=0 &t.fm!=1) /判断为真分数output(t.fz/t.fm(istream &input,Fraction &t)/重载输入运算符,输入分数 int a,c;char b;inputabc;if(b=/ & c!=0 )t.fz=a;t.fm=c;else退出重新输入!endl;return input;cout请输入:(0-3):/main函数#include#include分数计算器h.hint main(

13、)Integer dis;Fraction a,b,result,real;int m,z;char c; /数据类型dis.display ();while(m!=0)coutm;if(m=1) /分数与整数的运算coutendla;coutendlc;coutendlz;if(c=+)result=a+z;if(c=-)result=a-z;if(c=*)result=a*z;if(c=/)result=a/z;real=result.predigest();请输入一个分数:请输入运算符:输入一个正整数acz=a.predigest()cz=realendl; coutendl;if(m=

14、2) /整数与 分数的运算coutendl;coutendlz;coutendlc;coutendlb;if(c=+)result=b+z;if(c=-)result=z-b; if(c=*)result=b*z;if(c=/)result=z/b;real=result.predigest();cout运算式规范为:zcb=zcb.predigest()=realendl;coutendl;if(m=3)/分数与分数的运算coutendl;coutendla;coutendlc;coutendlb;if(c=+)result=a+b;if(c=-)result=a-b;if(c=*)result=a*b;if(c=/)result=a/b;real=result.predigest();cou

温馨提示

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

最新文档

评论

0/150

提交评论