/*。
*Copyright(c)2014,烟台大学计算机学院
*All right reserved,
*文件名:test.cpp
*作者:毕玉堂
*完成日期:2015年5月7日
*版本号:v1.0
*
问题描述:
*输入描述:
*程序输出:
*/
#include <iostream>
#include<Cmath>
#include<cstdlib>
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 set(int nu=0,int de=1);//置值,改变值时用
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);
void input(); //按照"nu/de"的格式,如"5/2"的形式输入
void simplify(); //化简(使分子分母没有公因子)
void amplify(int n); //放大n倍,如2/3放大5倍为10/3
void output(int style);
//输出:以8/6为例,style为0时,原样输出8/6;
//style为1时,输出化简后形式4/3;
//style为2时,输出1(1/3)形式,表示一又三分之一;
//0.3333;
//默认方式0
friend CFraction operator+(const CFraction &c,int i);
friend CFraction operator+(int i,const CFraction &c);
friend CFraction operator-(const CFraction &c,int i);
friend CFraction operator-(int i,const CFraction &c);
friend CFraction operator*(const CFraction &c,int i);
friend CFraction operator*(int i,const CFraction &c);
friend CFraction operator/(const CFraction &c,int i);
friend CFraction operator/(int i,const CFraction &c);
};
void CFraction::set(int nu,int de)
{
if(de!=0)
{
nume=nu;
deno=de;
}
}
CFraction CFraction::operator+(const CFraction &c)
{
CFraction a;
a.nume=nume*c.deno+c.nume*deno;
a.deno=deno*c.deno;
a.simplify();
return a;
}
CFraction CFraction::operator-(const CFraction &c)
{
CFraction a;
a.nume=nume*c.deno-c.nume*deno;
a.deno=deno*c.deno;
a.simplify();
return a;
}
CFraction CFraction::operator*(const CFraction &c)
{
CFraction a;
a.nume=nume*c.nume;
a.deno=deno*c.deno;
a.simplify();
return a;
}
CFraction CFraction::operator/(const CFraction &c)
{
CFraction a;
a.nume=nume*c.deno;
a.deno=deno*c.nume;
a.simplify();
return a;
}
bool CFraction::operator>(const CFraction &c)
{
if((nume*c.deno>c.nume*deno&&deno*c.deno>0)||(nume*c.deno<c.nume*deno&&deno*c.deno<0))
return true;
return false;
}
bool CFraction::operator<(const CFraction &c)
{
if((nume*c.deno<c.nume*deno&&deno*c.deno>0)||(nume*c.deno>c.nume*deno&&deno*c.deno<0))
return true;
return false;
}
bool CFraction::operator==(const CFraction &c)
{
if(*this!=c)
return false;
return true;
}
bool CFraction::operator!=(const CFraction &c)
{
if(*this>c||*this<c)
return true;
return false;
}
bool CFraction::operator>=(const CFraction &c)
{
if(*this<c)
return false;
return true;
}
bool CFraction::operator<=(const CFraction &c)
{
if(*this>c)
return false;
return true;
}
CFraction operator+(const CFraction &c,int i)
{
CFraction a;
a.nume=c.nume+i*c.deno;
a.deno=c.deno;
a.simplify();
return a;
}
CFraction operator+(int i,const CFraction &c)
{
CFraction a;
a.nume=c.nume+i*c.deno;
a.deno=c.deno;
a.simplify();
return a;
}
CFraction operator-(const CFraction &c,int i)
{
CFraction a;
a.nume=c.nume-i*c.deno;
a.deno=c.deno;
a.simplify();
return a;
}
CFraction operator-(int i,const CFraction &c)
{
CFraction a;
a.nume=i*c.deno-c.nume;
a.deno=c.deno;
a.simplify();
return a;
}
CFraction operator*(const CFraction &c,int i)
{
CFraction a;
a.nume=c.nume*i;
a.deno=c.deno;
a.simplify();
return a;
}
CFraction operator*(int i,const CFraction &c)
{
CFraction a;
a.nume=c.nume*i;
a.deno=c.deno;
a.simplify();
return a;
}
CFraction operator/(const CFraction &c,int i)
{
CFraction a;
a.nume=c.nume;
a.deno=c.deno*i;
a.simplify();
return a;
}
CFraction operator/(int i,const CFraction &c)
{
CFraction a;
a.nume=i*c.deno;
a.deno=c.nume;
a.simplify();
return a;
}
void CFraction::input()
{
int nu,de;
char a;
cout<<"输入分数(m/n形式)";
cin>>nu>>a>>de;
if(a!='/')
{
cout<<"输入形式错误";
}
else if(de==0)
{
cout<<"输入形式错误";
}
nume=nu;
deno=de;
}
void CFraction::simplify()
{
int n=gcd(deno, nume);
deno/=n; // 化简
nume/=n;
}
// 求m,n的最大公约数
int gcd(int m, int n) //这个函数可以定义为类的成员函数,也可以为一般函数
{
int r;
while(n!=0)
{
r=m%n;
m=n;
n=r;
}
return m;
}
void CFraction::amplify(int n)
{
nume*=n;
}
void CFraction::output(int style)
{
int n;
switch(style)
{
case 0:
cout<<"原样:" <<nume<<'/'<<deno<<endl;
break;
case 1:
n=gcd(deno, nume);
cout<<"化简形式: "<<nume/n<<'/'<<deno/n<<endl; //输出化简形式,并不是要化简
break;
case 2:
cout<<"带分数形式:" <<nume/deno<<'('<<nume%deno<<'/'<<deno<<')'<<endl;
break;
case 3:
cout<<"近似值:" <<nume/double(deno)<<endl;
break;
default:
cout<<"默认原样:" <<nume<<'/'<<deno<<endl;
}
}
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.output(0);
s=x-y;
cout<<"x-y=";
s.output(0);
s=x*y;
cout<<"x*y=";
s.output(0);
s=x/y;
cout<<"x/y=";
s.output(0);
x.output(0);
if (x>y) cout<<"大于"<<endl;
if (x<y) cout<<"小于"<<endl;
if (x==y) cout<<"等于"<<endl;
y.output(0);
cout<<endl;
CFraction c1(5,3),c2;
c2=c1+5;
c2.output(0);
c2=5+c1;
c2.output(0);
c2=c1-5;
c2.output(0);
c2=5-c1;
c2.output(0);
c2=c1*5;
c2.output(0);
c2=5*c1;
c2.output(0);
c2=c1/5;
c2.output(0);
c2=5/c1;
c2.output(0);
return 0;
}
运行结果: