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

下载本文档

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

文档简介

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

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

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

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

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

6、;" 分数计算器 "<<endl<<endl;cout<<" 请 选 择 功 能"<<endl;cout<<"1cout<<"2cout<<"3cout<<"0分数与整数的四则运算。 "<<endl<<endl; 整数与分数的四则运算。 "<<endl<<endl; 分数与分数的四则运算。 "<<endl<<endl;

7、输入 0 退出。 "<<endl<<endl;Fracti on Fraction:predigest()/定义约分函数int n,d,t,sign=1;Fraction temp;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;=sign*(fz/d);=fm/d;return temp;Fraction Fraction:operator+(Fraction &c)/ 重载两个分数的加法运算符Fraction temp;=fz*+fm*;=fm*;return temp;Fraction Fraction:operator+(int n)/ 重载分数和整数的加法运算Fraction temp;=fm*n+fz;=fm;return temp;Fraction operator-(int n,Fraction &a

9、mp;c)Fraction temp;=* ;一 J一 Jreturn temp;Fraction Fraction:operator-(int n)/ 重载分数减整数的减法运算符Fraction temp;=fz-fm*n;=fm;return temp;Fraction Fraction:operator-(Fraction &c) / 重载两个分数的减法运算符Fraction temp ;=fz* -fm*;=fm*;return temp;Fraction Fraction:operator*(Fraction &c)/ 重载两个分数的乘法运算符Fraction tem

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

11、n operator /(int n,Fraction &c)Fraction temp;=n* ;一 Jreturn temp;ostream& operator<<(ostream &output,Fraction &t) / 重载输出运算符,输出分数 int a,b,c;a=;b=;if(a=0|b=0)/ 当分子,或者分母为 0 时,输出 0cout<<"0"if(b=1) / 当分母为 1 时,输出分子 cout<<a;if(a>b&&b!=1) / 判断分数为假分数c=a/

12、b;a=a%b;cout<<c;if(a!=0)coutvv"又"vvavv'/'vvb;if(a<0&&-a>b&&b!=1)/ 当分数为负时,判断为假分数c=-a/b;a=-a%b;c=-c;cout<<'='<<c;if(a!=0)cout<<" 又 "<<a<<'/'<<b<<endl;if>0&&< && !=0&a

13、mp;&!=1)/ 判断为真分数output<<<<'/'<<if<0 && < && !=0 && !=1)/ 判断为真分数output<<"("<<<<'/'<<<<")"return output;istream& operator>>(istream &input,Fraction &t) / 重载输入运算符,输入分数

14、 int a,c;char b;input>>a>>b>>c;if(b='/' && c!=0 )=a;=c;else"<<endl;cout<<" 错误!输入格式错误或分母为 0!请退出重新输入! return input;/main 函数#include<> #include" 分数计算器 "int main()Integer dis;Fraction a,b,result,real;int m,z;char c;/ 数据类型();while(m!

15、=0)cout<<"请输入: (0-3): "cin>>m;if(m=1)/ 分数与整数的运算cout<<endl<<" 请输入一个分数:cin>>a;cin>>c;cout<<endl<<" 输入一个正整数cin>>z;if(c='+')result=a+z;if(c='-')result=a-z;if(c='*')result=a*z;if(c='/')result=a/z;rea

16、l=();cout<<" 运算式规范为:"<<a<<c<<z<<'='<< ()<<c<<z<<'='<<real<<endl;cout<<endl;if(m=2)/ 整数与分数的运算cout<<endl;cout<<endl<<"请输入一个正整数 :cin>>z;cout<<endl<<"请输入运算符 :ci

17、n>>c;cout<<endl<<"请输入一个分数 :cin>>b;if(c='+')result=b+z;if(c='-')result=z-b;if(c='*')result=b*z;if(c='/')result=z/b;real=();cout<<" 运算式规范为:"<<z<<c<<b<<'='<<z<<c<< ()<<&#

18、39;='<<real<<endl;cout<<endl;if(m=3)/ 分数与分数的运算cout<<endl;cout<<endl<<"请输入一个分数 :cin>>a;cout<<endl<<"请输入运算符 :cin>>c;cout<<endl<<"请输入一个分数cin>>b;if(c='+')result=a+b;if(c='-')result=a-b;if(c='*')result=a*b;if(c='/')result=a/b;real=();cout<<" 运算式规范为: "<<a<&

温馨提示

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

评论

0/150

提交评论