/*
*copyright (c)2015,烟台大学计算机学院
*All rights reserved
*文件名称:project.cpp
*作者:孙春红
*完成日期:2015年4月30日
*版本号:v1.0
*
*问题描述:在(1)的基础上,实现分数类中的对象和整型数的四则运算。
分数类中的对象可以和整型数进行四则运算,且运算符合交换律。例如
CFraction a(1,3),b; int i=2; 可以完成b=a+i;。同样,可以完成i+a,
45+a, a*27, 5/a等各种运算。
*输入描述:略。
*程序输出:略。
*/
#include<iostream>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
//构造函数及运算符重载的函数声明
CFraction(int nu=0,int de=1):nume(nu),deno(de) {}
void simplify();
void display ();
friend bool operator > (CFraction &c1,CFraction &c2);
friend bool operator < (CFraction &c1,CFraction &c2);
friend bool operator >=(CFraction &c1,CFraction &c2);
friend bool operator <=(CFraction &c1,CFraction &c2);
friend bool operator ==(CFraction &c1,CFraction &c2);
friend bool operator !=(CFraction &c1,CFraction &c2);
friend CFraction operator +(CFraction &c1,CFraction &c2);
friend CFraction operator -(CFraction &c1,CFraction &c2);
friend CFraction operator *(CFraction &c1,CFraction &c2);
friend CFraction operator /(CFraction &c1,CFraction &c2);
friend CFraction operator +(int d,CFraction &c);
friend CFraction operator -(int d,CFraction &c);
friend CFraction operator *(int d,CFraction &c);
friend CFraction operator /(int d,CFraction &c);
friend CFraction operator +(CFraction &c,int d);
friend CFraction operator -(CFraction &c,int d);
friend CFraction operator *(CFraction &c,int d);
friend CFraction operator /(CFraction &c,int d);
friend bool operator>( CFraction &c, int i);
friend bool operator>(int i,CFraction &c);
friend bool operator<( CFraction &c, int i);
friend bool operator<(int i,CFraction &c);
friend bool operator==( CFraction &c, int i);
friend bool operator==(int i,CFraction &c);
friend bool operator!=(CFraction &c, int i);
friend bool operator!=(int i,CFraction &c);
friend bool operator>=(CFraction &c, int i);
friend bool operator>=(int i,CFraction &c);
friend bool operator<=(CFraction &c, int i);
friend bool operator<=(int i,CFraction &c);
};
//重载函数的实现
void CFraction::simplify()
{
int r,m,n;
m=deno;
n=nume;
while(r=m%n) // 求m,n的最大公约数
{
m=n;
n=r;
}
deno/=n;
nume/=n;
}
void CFraction::display()
{
cout<<"("<<nume<<"/"<<deno<<")"<<endl;
}
bool operator > (CFraction &c1,CFraction &c2)
{
if ((c1.nume*c2.deno)>(c2.nume*c1.deno))
return true;
return false;
}
bool operator < (CFraction &c1,CFraction &c2)
{
if ((c1.nume*c2.deno)<(c2.nume*c1.deno))
return true;
return false;
}
bool operator >=(CFraction &c1,CFraction &c2)
{
if (c1<c2)
return false;
return true;
}
bool operator <=(CFraction &c1,CFraction &c2)
{
if (c1>c2)
return false;
return true;
}
bool operator ==(CFraction &c1,CFraction &c2)
{
if ((c1<c2)||(c1>c2))
return false;
return true;
}
bool operator !=(CFraction &c1,CFraction &c2)
{
if (c1==c2)
return false;
return true;
}
bool operator>(CFraction &c, int i)
{
if(c.deno>0)
return c.nume>(i*c.deno); //继续去判断“>”两边数的大小
else
return c.nume<(i*c.deno);
}
bool operator>(int i,CFraction &c)
{
if(c.deno>0)
return (i*c.deno)>c.nume;
else
return (i*c.deno)<c.nume;
}
bool operator<( CFraction &c, int i)
{
if(c.deno>0)
return c.nume<(i*c.deno);
else
return c.nume>(i*c.deno);
}
bool operator<(int i,CFraction &c)
{
if(c.deno>0)
return (i*c.deno)<c.nume;
else
return (i*c.deno)>c.nume;
}
bool operator==(CFraction &c, int i)
{
return c.nume==(i*c.deno);
}
bool operator==(int i, CFraction &c)
{
return c.nume==(i*c.deno);
}
bool operator!=( CFraction &c, int i)
{
return c.nume!=(i*c.deno);
}
bool operator!=(int i, CFraction &c)
{
return c.nume!=(i*c.deno);
}
bool operator>=( CFraction &c, int i)
{
return !(c<i);
}
bool operator>=(int i, CFraction &c)
{
return !(i<c);
}
bool operator<=( CFraction &c, int i)
{
return !(c>i);
}
bool operator<=(int i,CFraction &c)
{
return !(i>c);
}
CFraction operator +(CFraction &c1,CFraction &c2)
{
CFraction c;
c.deno=c1.deno*c2.deno;
c.nume=c1.nume*c2.deno+c2.nume*c1.deno;
c.simplify();
return c;
}
CFraction operator -(CFraction &c1,CFraction &c2)
{
CFraction c;
c.deno=c1.deno*c2.deno;
c.nume=c1.nume*c2.deno-c2.nume*c1.deno;
c.simplify();
return c;
}
CFraction operator *(CFraction &c1,CFraction &c2)
{
CFraction c;
c.deno=c1.deno*c2.deno;
c.nume=c1.nume*c2.nume;
c.simplify();
return c;
}
CFraction operator /(CFraction &c1,CFraction &c2)
{
CFraction c;
c.deno=c1.deno*c2.nume;
c.nume=c1.nume*c2.deno;
c.simplify();
return c;
}
CFraction operator +(int d,CFraction &c)
{
CFraction c1;
c1.deno=c.deno;
c1.nume=c.nume+d*c.deno;
c1.simplify();
return c1;
}
CFraction operator +(CFraction &c,int d)
{
CFraction c1;
c1.deno=c.deno;
c1.nume=c.nume+d*c.deno;
c1.simplify();
return c1;
}
CFraction operator -(int d,CFraction &c)
{
CFraction c1;
c1.deno=c.deno;
c1.nume=d*c.deno-c.nume;
c1.simplify();
return c1;
}
CFraction operator -(CFraction &c,int d)
{
CFraction c1;
c1.deno=c.deno;
c1.nume=c.nume-d*c.deno;
c1.simplify();
return c1;
}
CFraction operator *(int d,CFraction &c)
{
CFraction c1;
c1.deno=c.deno;
c1.nume=d*c.nume;
c1.simplify();
return c1;
}
CFraction operator *(CFraction &c,int d)
{
CFraction c1;
c1.deno=c.deno;
c1.nume=d*c.nume;
c1.simplify();
return c1;
}
CFraction operator /(CFraction &c,int d)
{
CFraction c1;
c1.deno=c.deno*d;
c1.nume=c.nume;
c1.simplify();
return c1;
}
CFraction operator /(int d,CFraction &c)
{
CFraction c1;
c1.deno=c.nume;
c1.nume=d*c.deno;
c1.simplify();
return c1;
}
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.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;
s=x-1;
cout<<"x-1=";
s.display();
if (x>s) cout<<"大于"<<endl;
if (x<s) cout<<"小于"<<endl;
if (x==s) cout<<"等于"<<endl;
return 0;
}
运行结果:
知识点总结:
运用友元函数实现分数类中的运算符重载。
学习心得:
好长的代码。。。因为定义的时候错了一个小字母,结果,从头改到位。。。。