#include <iostream>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; //分母
public:
//构造函数及运算符重载的函数声明
CFraction(int n=0,int d=0):nume(n),deno(d) {}
friend CFraction operator+(const CFraction &a,const CFraction &b);
friend CFraction operator-(const CFraction &a,const CFraction &b);
friend CFraction operator*(const CFraction &a,const CFraction &b);
friend CFraction operator/(const CFraction &a,const CFraction &b);
friend bool operator>(const CFraction &a,const CFraction &b);
friend bool operator<(const CFraction &a,const CFraction &b);
friend bool operator==(const CFraction &a,const CFraction &b);
friend bool operator!=(const CFraction &a,const CFraction &b);
friend bool operator>=(const CFraction &a,const CFraction &b);
friend bool operator<=(const CFraction &a,const CFraction &b);
friend CFraction operator+(const CFraction &b,int i);
friend CFraction operator-(const CFraction &b,int i);
friend CFraction operator*(const CFraction &b,int i);
friend CFraction operator/(const CFraction &b,int i);
friend ostream& operator<<(ostream &output,CFraction &c);
void display();
};
int simple(int,int);
CFraction operator+(const CFraction &a,const CFraction &b)
{
CFraction c;
c.deno=a.deno*b.deno;
c.nume=a.nume*b.deno+a.deno*b.nume;
int x;
x=simple(c.nume,c.deno);
c.nume/=x;
c.deno/=x;
return c;
}
CFraction operator-(const CFraction &a,const CFraction &b)
{
CFraction c;
c.deno=a.deno*b.deno;
c.nume=a.nume*b.deno-a.deno*b.nume;
int x;
x=simple(c.nume,c.deno);
c.nume/=x;
c.deno/=x;
return c;
}
CFraction operator*(const CFraction &a,const CFraction &b)
{
CFraction c;
c.deno=a.deno*b.deno;
c.nume=a.nume*b.nume;
int x;
x=simple(c.nume,c.deno);
c.nume/=x;
c.deno/=x;
return c;
}
CFraction operator/(const CFraction &a,const CFraction &b)
{
CFraction c;
c.deno=a.deno*b.nume;
c.nume=a.nume*b.deno;
int x;
x=simple(c.nume,c.deno);
c.nume/=x;
c.deno/=x;
return c;
}
bool operator>(const CFraction &a,const CFraction &b)
{
if(a.nume*b.deno>a.deno*b.nume)
return true;
else
return false;
}
bool operator<(const CFraction &a,const CFraction &b)
{
if(a.nume*b.deno<a.deno*b.nume)
return true;
else
return false;
}
bool operator==(const CFraction &a,const CFraction &b)
{
if(a.nume*b.deno==a.deno*b.nume)
return true;
else
return false;
}
bool operator!=(const CFraction &a,const CFraction &b)
{
if(a.nume*b.deno!=a.deno*b.nume)
return true;
else
return false;
}
bool operator>=(const CFraction &a,const CFraction &b)
{
if(a<b)
return false;
else
return true;
}
bool operator<=(const CFraction &a,const CFraction &b)
{
if(a>b)
return false;
else
return true;
}
CFraction operator+(const CFraction &a,int i)
{
CFraction c;
c.deno=a.deno;
c.nume=a.nume+i*a.deno;
return c;
}
CFraction operator-(const CFraction &a,int i)
{
CFraction c;
c.deno=a.deno;
c.nume=a.nume-i*a.deno;
return c;
}
CFraction operator*(const CFraction &a,int i)
{
CFraction c;
c.deno=a.deno;
c.nume=a.nume*i;
int x;
x=simple(c.nume,c.deno);
c.nume/=x;
c.deno/=x;
return c;
}
CFraction operator/(const CFraction &a,int i)
{
CFraction c;
c.deno=a.deno*i;
c.nume=a.nume;
int x;
x=simple(c.nume,c.deno);
c.nume/=x;
c.deno/=x;
return c;
}
ostream& operator<<(ostream &output,CFraction &c)
{
output<<c.nume<<"/"<<c.deno;
return output;
}
int simple(int n,int d)
{
int r;
if(n<d)
{
r=n;
n=d;
d=r;
}
while(r=n%d)
{
n=d;
d=r;
}
return n;
}
void CFraction::display()
{
cout<<"分子/分母:"<<nume<<"/"<<deno<<endl;
}
int main()
{
CFraction a(1,3),b,c(2,5),d(5,8),e(7,6),f(3,5),g(3,8);
int i=2;
b=a+i;
b.display();
c=a+b;
c.display();
c=a-i;
c.display();
c=a-b;
c.display();
c=a*i;
c.display();
c=a*b;
c.display();
c=a/i;
c.display();
c=a/b;
c.display();
if(a>d)
cout<<a<<">"<<d<<endl;
else if(a==d)
cout<<a<<"="<<d<<endl;
else
cout<<a<<"<"<<d<<endl;
if(a<e)
cout<<a<<"<"<<e<<endl;
else
cout<<a<<">="<<e<<endl;
if(a>=f)
cout<<a<<">="<<f<<endl;
else
cout<<a<<"<"<<f<<endl;
if(a<=g)
cout<<a<<"<="<<g<<endl;
else
cout<<a<<">"<<g<<endl;
return 0;
}
感觉代码有点多,但都是千篇一律也不算太难,主要输出那地方为了把运算符重载函数都用上弄的有点乱,也不知道对不对了。在此有点尴尬。