/*
*程序的版权和版本声明部分:
*Copyright(c)2014,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:田成琳
*完成日期:2014 年 4 月 15 日
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述:无
*问题描述:实现分数类中的运算符重载,在分数类中可以完成分数的加减乘除(运算后再化简)、
比较(6种关系)的运算
*程序输出:- -
*问题分析:
*算法设计:
*/
#include<iostream>
#include<cmath>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction(int n=0,int d=0);
void set(int n,int d);
bool operator > (CFraction &a);
bool operator < (CFraction &a);
bool operator >= (CFraction &a);
bool operator <= (CFraction &a);
bool operator == (CFraction &a);
bool operator != (CFraction &a);
CFraction operator + (const CFraction &a);
CFraction operator - (const CFraction &a);
CFraction operator * (const CFraction &a);
CFraction operator / (const CFraction &a);
CFraction operator + ();
CFraction operator - ();
friend istream & operator >> (istream &in,CFraction &a);
friend ostream & operator << (ostream &out,CFraction &a);
void simplify();
int gongbeis(int,int);
};
CFraction::CFraction(int n,int d)
{
nume=n;
deno=d;
}
void CFraction::set(int n,int d)
{
nume=n;
deno=d;
}
bool CFraction::operator > (CFraction &a)
{
int de,nu1=nume,nu2=a.nume;
de=a.deno*deno;
nu1*=a.deno;
nu2*=deno;
if(nu1-nu2>0)
return true;
else
return false;
}
bool CFraction::operator < (CFraction &a)
{
int de,nu1=nume,nu2=a.nume;
de=a.deno*deno;
nu1*=a.deno;
nu2*=deno;
if(nu1-nu2<0)
return true;
else
return false;
}
bool CFraction::operator >= (CFraction &a)
{
int de,nu1=nume,nu2=a.nume;
de=a.deno*deno;
nu1*=a.deno;
nu2*=deno;
if(nu1-nu2>=0)
return true;
else
return false;
}
bool CFraction::operator <= (CFraction &a)
{
int de,nu1=nume,nu2=a.nume;
de=a.deno*deno;
nu1*=a.deno;
nu2*=deno;
if(nu1-nu2<=0)
return true;
else
return false;
}
bool CFraction::operator == (CFraction&a)
{
int de,nu1=nume,nu2=a.nume;
de=a.deno*deno;
nu1*=a.deno;
nu2*=deno;
if(nu1-nu2==0)
return true;
else
return false;
}
bool CFraction::operator != (CFraction &a)
{
int de,nu1=nume,nu2=a.nume;
de=a.deno*deno;
nu1*=a.deno;
nu2*=deno;
if(nu1-nu2!=0)
return true;
else
return false;
}
CFraction CFraction::operator+(const CFraction &c)
{
CFraction t;
t.nume=nume*c.deno+c.nume*deno;
t.deno=deno*c.deno;
t.simplify();
return t;
}
CFraction CFraction:: operator-(const CFraction &c)
{
CFraction t;
t.nume=nume*c.deno-c.nume*deno;
t.deno=deno*c.deno;
t.simplify();
return t;
}
CFraction CFraction:: operator*(const CFraction &c)
{
CFraction t;
t.nume=nume*c.nume;
t.deno=deno*c.deno;
t.simplify();
return t;
}
CFraction CFraction:: operator/(const CFraction &c)
{
CFraction t;
if (!c.nume)
return *this;
t.nume=nume*c.deno;
t.deno=deno*c.nume;
t.simplify();
return t;
}
istream & operator >> (istream &in,CFraction &a)
{
char sign;
in>>a.nume>>sign>>a.deno;
while(sign!='/')
{
cout<<"格式错误,请重新输入:"<<endl;
in>>a.nume>>sign>>a.deno;
}
return in;
}
ostream & operator << (ostream &out,CFraction &a)
{
out<<a.nume<<"/"<<a.deno<<endl;
return out;
}
CFraction CFraction::operator + ()
{
return *this;
}
CFraction CFraction::operator - ()
{
CFraction t;
t.nume=nume;
t.deno=-deno;
return t;
}
int main()
{
CFraction t,t1,t2,t3,t4,t5,t6,t7;
cout<<"请输入两个分数(a/b形式):"<<endl;
cin>>t>>t1;
t2=t+t1;
t3=t-t1;
t4=t*t1;
t5=t/t1;
t6=+t+t1;
t7=-t+t1;
cout<<"相加="<<t2<<"相减="<<t3<<endl;
cout<<"相乘="<<t4<<"相除="<<t5<<endl;
cout<<"取正相加="<<t6<<"取反相加="<<t7<<endl;
return 0;
}
void CFraction::simplify()
{
int m,n,r;
n=abs(deno);
m=abs(nume);
while(r=m%n)
{
m=n;
n=r;
}
deno/=n;
nume/=n;
if (deno<0)
{
deno=-deno;
nume=-nume;
}
}
运行结果:
心得体会:第一次把内部私有数据都给改了,导致运行不对,,,看来下次得好好先看清需求。。。