#include <iostream>
#include <Cmath>
using namespace std;
int gcd(int m,int n);
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction(int nu=0,int de=1):nume(nu),deno(de){} ;
void simplify();
void display();
CFraction operator+(const CFraction &c); //两个分数相加,结果要化简
CFraction operator-(const CFraction &c); //两个分数相减,结果要化简
CFraction operator*(const CFraction &c); //两个分数相乘,结果要化简
CFraction operator/(const CFraction &c); //两个分数相除,结果要化简
bool operator>(const CFraction &c);
bool operator<(const CFraction &c);
bool operator==(const CFraction &c);
bool operator!=(const CFraction &c);
bool operator>=(const CFraction &c);
bool operator<=(const CFraction &c);
};
int gcd(int m, int n)
{
int r;
if (m<n){r=m;m=n;n=r;}
while(r=m%n) // 求m,n的最大公约数
{
m=n;
n=r;
}
return n;
}
void CFraction::display()
{
cout<<nume<<"/"<<deno<<endl;
}
void CFraction::simplify()
{
int n=gcd(deno, nume);
deno=deno/n; // 化简
nume=nume/n;
}
CFraction CFraction::operator+(const CFraction &c)
{
int a,b,d,sum1,sum2;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b+d;//分子
sum2=a;
CFraction f(sum1,sum2);
return f;
}
CFraction CFraction::operator-(const CFraction &c)
{
int a,b,d,sum1,sum2;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b-d;//分子
sum2=a;
CFraction f(sum1,sum2);
return f;
}
CFraction CFraction::operator*(const CFraction &c)
{
int sum1,sum2;
sum1=nume*c.nume;//分子
sum2=deno*c.deno;
CFraction f(sum1,sum2);
return f;
}
CFraction CFraction::operator/(const CFraction &c)
{
int sum1,sum2;
sum1=nume*c.deno;//分子
sum2=deno*c.nume;
CFraction f(sum1,sum2);
return f;
}
bool CFraction::operator>(const CFraction &c)
{
int a,b,d,sum1;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b-d;//分子
if(sum1>0) return true;
return false;
}
bool CFraction::operator<(const CFraction &c)
{
int a,b,d,sum1;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b-d;//分子
if(sum1>0) return false;
return true;
}
bool CFraction::operator>=(const CFraction &c)
{
int a,b,d,sum1;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b-d;//分子
if(sum1>=0) return true;
return false;
}
bool CFraction::operator<=(const CFraction &c)
{
int a,b,d,sum1;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b-d;//分子
if(sum1>=0) return false;
return true;
}
bool CFraction::operator==(const CFraction &c)
{
int a,b,d,sum1;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b-d;//分子
if(sum1==0) return true;
return false;
}
bool CFraction::operator!=(const CFraction &c)
{
int a,b,d,sum1;
a=deno*c.deno;
b=nume*c.deno;
d=c.nume*deno;
sum1=b-d;//分子
if(sum1!=0) return true;
return false;
}
int main()
{
CFraction x(1,3),y(-5,10),s;
cout<<"分数x=1/3 y=-5/10"<<endl;
s.display();
s=x-y;
cout<<"x-y=";
s.display();
s=x*y;
cout<<"x*y=";
s.display();
s=x/y;
cout<<"x/y=";
s.display();
x.display();
if (x>y) cout<<"大于"<<endl;
if (x<y) cout<<"小于"<<endl;
if (x==y) cout<<"等于"<<endl;
y.display();
cout<<endl;
return 0;
}
运行结果