




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 明确责任的工作目标设定计划
- 如何提升财务团队的协作效率计划
- 2025年鞋用乳液胶粘剂项目合作计划书
- 2025年医用冷疗项目发展计划
- 2025年其它核材料及相关特殊材料合作协议书
- 远程在线教育平台学习免责协议
- 电动汽车充电桩安装施工合同
- Rac-Ganoderic-acid-C2-生命科学试剂-MCE
- 财务顾问聘用协议
- 工作总结写作培训
- GB/T 4214.2-2020家用和类似用途电器噪声测试方法真空吸尘器的特殊要求
- GB/T 3215-2019石油、石化和天然气工业用离心泵
- 蔬菜采购项目投标书
- 肩周炎康复护理
- 2022年安徽管子文化旅游集团有限公司招聘笔试试题及答案解析
- SAPPM设备管理解决方案
- Q-HN-1-0000.08.004《风力发电场电能质量监督技术标准》
- 多指畸形-课件
- 5G NSA站点开通指导书(临时IP开站)
- 死亡患者尸检同意书
- 正常心电图学课件
评论
0/150
提交评论