问题及代码:
/*。
*Copyright(c)2014,烟台大学计算机学院
*All right reserved,
*文件名:test.cpp
*作者:liu_feng_zi_
*完成日期:2015年5月12日
*版本号:v1.0
*问题描述:实现分数类中的运算符重载,
在分数类中可以完成分数的加减乘除(运算后再化简)、比较(6种关系)的运算。
定义分数一目运算+、-,分别代表取正和求反,将”按位取反运算符“~重载为分数的求倒数运算。
*输入描述:
*程序输出:
*/
#include <iostream>
#include <cmath>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction();
CFraction(int n,int d);
CFraction operator+(CFraction &c);
CFraction operator-(CFraction &c);
CFraction operator*(CFraction &c);
CFraction operator/(CFraction &c);
CFraction operator+();
CFraction operator-();
CFraction operator~();
void simplify();
bool operator>(CFraction &c);
bool operator<(CFraction &c);
bool operator>=(CFraction &c);
bool operator<=(CFraction &c);
bool operator==(CFraction &c);
bool operator!=(CFraction &c);
friend istream&operator>>(istream&,CFraction&);
friend ostream&operator<<(ostream&,CFraction&);
};
CFraction::CFraction()
{
nume=0;
deno=0;
}
CFraction::CFraction(int n,int d)
{
nume=n;
deno=d;
}
CFraction CFraction::operator+(CFraction &c)
{
CFraction c1;
c1.deno=deno*c.deno;
c1.nume=nume*c.deno+deno*c.nume;
c1.simplify();
return c1;
}
CFraction CFraction::operator-(CFraction &c)
{
CFraction c1;
c1.deno=deno*c.deno;
c1.nume=nume*c.deno-deno*c.nume;
c1.simplify();
return c1;
}
CFraction CFraction::operator*(CFraction &c)
{
CFraction c1;
c1.deno=deno*c.deno;
c1.nume=nume*c.nume;
c1.simplify();
return c1;
}
CFraction CFraction::operator/(CFraction &c)
{
CFraction c1;
c1.deno=deno*c.nume;
c1.nume=nume*c.deno;
c1.simplify();
return c1;
}
bool CFraction::operator>(CFraction &c)
{
nume*=c.deno;
c.nume*=deno;
if(nume>c.nume)
return true;
return false;
}
bool CFraction::operator<(CFraction &c)
{
nume*=c.deno;
c.nume*=deno;
if(nume<c.nume)
return true;
return false;
}
bool CFraction::operator>=(CFraction &c)
{
nume*=c.deno;
c.nume*=deno;
if(nume<c.nume)
return false;
return true;
}
bool CFraction::operator<=(CFraction &c)
{
nume*=c.deno;
c.nume*=deno;
if(nume>c.nume)
return false;
return true;
}
bool CFraction::operator==(CFraction &c)
{
nume*=c.deno;
c.nume*=deno;
if(nume==c.nume)
return true;
return false;
}
bool CFraction::operator!=(CFraction &c)
{
nume*=c.deno;
c.nume*=deno;
if(nume!=c.nume)
return true;
return false;
}
void CFraction::simplify()
{
int x,y,n;
x=nume;
y=deno;
if(x<y)
{
n=x;
x=y;
y=n;
}
while(y!=0)
{
n=x%y;
x=y;
y=n;
}
nume/=x;
deno/=x;
}
CFraction CFraction::operator+()
{
return CFraction(fabs(nume),fabs(deno));
}
CFraction CFraction::operator-()
{
if(nume<0||deno<0)
return CFraction(fabs(nume),fabs(deno));
else
return CFraction(-nume,deno);
}
CFraction CFraction::operator~()
{
return CFraction(deno,nume);
}
istream&operator>>(istream&in,CFraction&c)
{
in>>c.nume>>c.deno;
return in;
}
ostream&operator<<(ostream&out,CFraction&c)
{
out<<c.nume<<"/"<<c.deno<<endl;
return out;
}
int main()
{
CFraction x(1,3),y(-5,10),s;
cout<<"分数x=1/3 y=-5/10"<<endl;
s=x+y;
cout<<"x+y="<<s;
s=x-y;
cout<<"x-y="<<s;
s=x*y;
cout<<"x*y="<<s;
s=x/y;
cout<<"x/y="<<s;
s=~y;
cout<<"求y倒数:"<<s;
s=+y;
cout<<"取正(y):"<<s;
s=-x;
cout<<"求反(x):"<<s;
cout<<"x="<<x<<"y="<<y;
if (x>y) cout<<"大于"<<endl;
if (x<y) cout<<"小于"<<endl;
if (x==y) cout<<"等于"<<endl;
return 0;
}
<span style="font-family:Arial;background-color: rgb(255, 255, 255);">运行结果:<img src="https://img-blog.csdn.net/20150512221553350?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGl1X2Zlbmdfemlf/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" /></span>