/*copyright(c)2016.烟台大学计算机学院
* All rights reserved,
* 文件名称:text.Cpp
* 作者:刘涛
* 完成日期:2016年5月21日
* 版本号:vc++6.0
*问题描述:实现分数类中的运算符重载,在分数类中可以完成分数的加减乘除(运算后再化简)、比较(6种关系)的运算。
*/
#include <iostream>
#include <Cmath>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction(int nu=1,int de=1):nume(nu),deno(de) {}
friend CFraction operator+(const CFraction &c1,const CFraction &c2);//重载加法
friend CFraction operator-(const CFraction &c1,const CFraction &c2);//重载减法
friend CFraction operator*(const CFraction &c1,const CFraction &c2);//重载乘法
friend CFraction operator/(const CFraction &c1,const CFraction &c2);//重载除法
//二目的比较运算符重载
bool operator > (const CFraction &c2);
bool operator < (const CFraction &c2);
bool operator >= (const CFraction &c2);
bool operator <= (const CFraction &c2);
bool operator == (const CFraction &c2);
bool operator != (const CFraction &c2);
//输入输出的重载
friend istream &operator>>(istream &in,CFraction &x);
friend ostream &operator<<(ostream &out,CFraction x);
void simplify();//分数化简
};
// 重载输入运算符>>
istream &operator>>(istream &in,CFraction &x)
{
char ch;
while(1)
{
cin>>x.nume>>ch>>x.deno;
if (x.deno==0)
cerr<<"分母为0, 请重新输入\n";
else if(ch!='/')
cerr<<"格式错误(形如m/n)! 请重新输入\n";
else
break;
}
return cin;
}
// 重载输出运算符<<
ostream &operator<<(ostream &out,CFraction x)
{
cout<<x.nume<<'/'<<x.deno;
return cout;
}
//重载加法
CFraction operator+(const CFraction &c1,const CFraction &c2)
{
CFraction a;
a.nume=c1.nume*c2.deno+c2.nume*c1.deno;
a.deno=c1.deno*c2.deno;
a.simplify();
return a;
}
//重载减法
CFraction operator-(const CFraction &c1,const CFraction &c2)
{
CFraction a;
a.nume=c1.nume*c2.deno-c2.nume*c1.deno;
a.deno=c1.deno*c2.deno;
a.simplify();
return a;
}
//重载乘法
CFraction operator*(const CFraction &c1,const CFraction &c2)
{
CFraction a;
a.nume=c1.nume*c2.nume;
a.deno=c1.deno*c2.deno;
a.simplify();
return a;
}
//重载除法
CFraction operator/(const CFraction &c1,const CFraction &c2)
{
CFraction a;
a.nume=c1.nume*c2.deno;
a.deno=c1.deno*c2.nume;
a.simplify();
return a;
}
//二目的比较运算符重载
bool CFraction:: operator > (const CFraction &c2)
{
int this_nume,c2_nume;
this_nume=nume*c2.deno;
c2_nume=c2.nume*deno;
if(this_nume>c2_nume)
return true;
return false;
}
bool CFraction:: operator < (const CFraction &c2)
{
int this_nume,c2_nume;
this_nume=nume*c2.deno;
c2_nume=c2.nume*deno;
if(this_nume<c2_nume)
return true;
return false;
}
bool CFraction::operator==(const CFraction &c2)
{
if (*this!=c2) return false;
return true;
}
bool CFraction::operator!=(const CFraction &c2)
{
if (*this>c2 || *this<c2) return true;
return false;
}
bool CFraction::operator>=(const CFraction &c2)
{
if (*this<c2) return false;
return true;
}
bool CFraction::operator<=(const CFraction &c2)
{
if (*this>c2) return false;
return true;
}
void CFraction::simplify()
{
int de,nu,r;
de=fabs(deno);
nu=fabs(nume);
while(r=nu%de) // 求m,n的最大公约数
{
nu=de;
de=r;
}
deno/=de; // 化简
nume/=de;
if (deno<0) // 将分母转化为正数
{
deno=-deno;
nume=-nume;
}
}
int main()
{
CFraction c1,c2,s;
cout<<"输入c1: ";
cin>>c1;
cout<<"输入c2: ";
cin>>c2;
s=c1+c2;
cout<<"c1+c2="<<s<<endl;;
s=c1-c2;
cout<<"c1-c2="<<s<<endl;;
s=c1*c2;
cout<<"c1*c2="<<s<<endl;;
s=c1/c2;
cout<<"c1/c2="<<s<<endl;;
if (c1>c2) cout<<"c1>c2"<<endl;
if (c1<c2) cout<<"c1<c2"<<endl;
if (c1==c2) cout<<"c1=c2"<<endl;
if (c1!=c2) cout<<"c1≠c2"<<endl;
if (c1>=c2) cout<<"c1≥c2"<<endl;
if (c1<=c2) cout<<"c1<=c2"<<endl;
return 0;
}
运行结果:
<img src="https://img-blog.csdn.net/20160521140308043?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
心得:还没有闹明白为什么<< >> 不可以直接用还得重载。
还有一个疑问就是运算符!=和=重载的时候为什么不能正面否定,而选择否定它的对立面呢,我试过直接否定它但是运行有错误。