分数计算器设计_第1页
分数计算器设计_第2页
分数计算器设计_第3页
分数计算器设计_第4页
分数计算器设计_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

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

文档简介

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

2、以下步骤:(1)应用系统分析,建立该系统的功能模块框图以及界面的组织和设计;头文件声明整数类声明派生类主函数成员函数定义定义类的对象定义成员函数(2)分析系统中的各个实体及它们之间的关系;Man豳成饮15獭» ,objmain.exeI(3)根据问题描述,设计系统的类层次;(4)完成类层次中各个类的描述;(5)完成类中各个成员函数的定义;(6)完成系统的应用模块;(7)功能调试;(8)完成系统总结报告.源代码:/分数计算器h.h:#include<iostream.h> class Integer / 整数类 (protected:int fz;int fm;public

3、:Integer(int a=0,int b=1):fz(a),fm(b)Integer()void display();classFraction:publicInteger/分数类,进行计算和输入输出public:Fraction(int a=0,int b=1):Integer(a,b)friend istream & operator>>(istream & ,Fraction & );/重载输入流friend ostream & operator<<(ostream & .Fraction& );/重载输出流Fr

4、actionoperator+(Fraction&c);/重载+运算符(分数与分数)Fractionoperator+(intn);/重载+运算符(整数与分数)Fractionoperator-(Fraction&c);/重载-运算符(分数与分数)Fractionoperator-(intn);/重载-运算符(整数与分数)friend Fraction operator-(int n,Fraction &c);Fractionoperator*(Fraction&c);/重载*运算符(分数与分数)Fractionoperator*(intn);/重载*运算符(整

5、数与分数)Fraction operator/(Fraction &c);/重载/运算符(分数与分数)Fraction operator/(int n);/ 重载/运算符(整数与分数)friend Fraction operator/(int n,Fraction &c);Fraction predigest(); /约分函数void display(););/实现函数(分数计算器设计)#include<iostream.h>分数计#include"分数计算器h.h" void Integer:display () cout<<end

6、l; cout<<算器"<<endl<<endl;cout<< "<<endl;cout<<"1四那么运算."<<endl<<endl;cout<<"2四那么运算."<<endl<<endl;cout<<"3四那么运算."<<endl<<endl;cout<<"0"<<endl<<endl; )

7、 Fraction Fraction:predigest()/ ( int n,d,t,sign=1; Fraction temp;请选择功能:分数与整数的整数与分数的分数与分数的输入0退出.定义约分函数if(fz<0 && fm<0) ( fz=-fz; fm=-fm; ) if(fz>0 && fm<0) ( fm=-fm;sign=-1;)if(fz<0 && fm>0)(fz=-fz;sign=-1;)n=fz;d=fm;int r;if(n<d)/辗转相除,求分子n与分母d的最大公约数t=n;n

8、=d;d=t;r=n%d;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.

9、fm=fm;return temp;)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 &c) /两个分数的减法运算符重载Fraction temp ;temp.

10、fz =fz*c.fm -fm*c.fz;temp.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;return temp;)Fraction Fraction:operator/(Fract

11、ion &c)载两个分数的除法运算符/重(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&

12、operator<<(ostream &output,Fraction &t)/重载输出运算符,输出分数(int a,b,c;a=t.fz;b=t.fm;if(a=0|b=0)/当分子,或者分母为0时,输出0cout<<"0"if(b=1)/当分母为1时,输出分cout<<a;if(a>b&&b!=1)/判断分数为假分数c=a/b;a=a%b;cout«c;if(a!=O)cout«" X',«a<<7,«b;)if(a<0&

13、amp;&-a>b&&b!=1)/当分数为负时,判断为假分数(c=-a/b;a=-a%b;c=-c;cout«'='«c;if(a!=O)cout«" X"«a«7'<<b«endl;)if(t.fz>O&&t.fz<t.fm && t.fm!=0&&t.fm!=1)/判断为真分数output<<t.fz«7'«t.fm;if(t.fz<0 &a

14、mp;& -t.fz<t.fm && t.fm!=O && t.fm!=1)/判断为真分数output«"("«t.fz«7'«t.fm<<")"return output;)istream& operator>>(istream &input,Fraction &t)/重载输入运算符,输入分数 int a,c;char b;input>>a>>b>>c;if(b='/&

15、#39; && c!=0 )t.fz=a;t.fm=c;)elsecout<<"错误! ! !输入格式错误或分母为0!请退出重新输入! "<<endl;return input;)/main函数#include<iostream.h>#include分数计算器h.h"int main()Integer dis;int m,z;char c; /数据类型dis.display ();while(m!=0)cout<<"请输入:(0-3):"cin>>m;if(m=1)/c

16、out<<endl<<" cin>>a;cout<<endl<<" cin>>c;cout<<endl<<" cin>>z;if(c='+') result=a+z;if(c='-') result=a-z;if(c='*') result=a*z;分数与整数的运算请输入一个分数:请输入运算符:输入一个正整数:result=a/z;real=result.predigest();cout<<&quo

17、t; 运 算 式 规 范 为"<<a<<c<<z<<'='<<a.predigest()<<c<<z<<'='<<real<<endl;cout<<endl;)if(m=2)/整数与分数的运算cout<<endl;cout<<endl<<"cin>>z;cout<<endl<<" cin>>c;cout<<e

18、ndl<<" cin>>b;if(c='+')result=b+z;if(c='-') result=z-b;if(c='*') result=b*z;请输入一个正整数请输入运算符:"请输入一个分数:"if(c='/')result=z/b;real=result.predigest();cout<<" 运 算 式 规 范 为"<<z<<c<<b<<'='<<z<<c<<b.predigest()<<'='<<real<<endl;cout<<endl;if(m=3)/运算cout<<endl;cout<<endl<<"cin>>

温馨提示

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

评论

0/150

提交评论