*烟台大学计算机学院学生
*All right reserved.
*文件名称*烟台大学计算机学院学生
*All right reserved.
*文件名称:项目3~~分数类的运算符重载
*作者:杨飞
*完成日期:2014年4月11日
*版本号:v1.0
*对任务及求解方法的描述部分:项目3~~分数类的运算符重载
*我的程序:
#include <iostream>
using namespace std;
class CFraction
{
private:
int zi; // 分子
int mu; // 分母
public:
CFraction operator +( CFraction &t);
CFraction operator -( CFraction &t);
CFraction operator *( CFraction &t);
CFraction operator /( CFraction &t);
CFraction (int x=0,int y=0);
void set(int x,int y);
void simply();
void display();
bool operator >( CFraction &t);
bool operator <( CFraction &t);
bool operator >=( CFraction &t);
bool operator <=( CFraction &t);
bool operator ==( CFraction &t);
bool operator !=( CFraction &t);
};
CFraction::CFraction(int x,int y)
{
zi=x;
mu=y;
}
void CFraction::set (int x,int y)
{
zi=x;
mu=y;
}
void CFraction::display()
{
cout<<zi<<"/"<<mu<<endl;
}
void CFraction::simply()
{
int i;
int m;
if(zi>mu)
m=mu;
else
m=zi;
for(i=2;i<=m;i++)
{
if(zi%i==0&&mu%i==0)
{
zi/=i;
mu/=i;
}
}
cout<<"化简之后的结果:"<<endl;
}
CFraction CFraction::operator +( CFraction &t)
{
CFraction p;
int m;
int c;
int num1,num2;
m=mu*t.mu;
for(int i=2;i<m;i++)
{
if((i%mu==0)&&(i%t.mu==0))
{
c=i;
break;
}
}
num1=c/mu;
num2=c/t.mu;
p.zi=zi*num1+t.zi*num2;
p.mu=c;
return p;
}
CFraction CFraction::operator -( CFraction &t)
{
CFraction p;
int m;
int c;
int num1,num2;
m=mu*t.mu;
for(int i=2;i<m;i++)
{
if((i%mu==0)&&(i%t.mu==0))
{
c=i;
break;
}
}
num1=c/mu;
num2=c/t.mu;
p.zi=zi*num1-t.zi*num2;
p.mu=c;
return p;
}
CFraction CFraction::operator *( CFraction &t)
{
CFraction p;
p.zi=zi*t.zi;
p.mu=mu*t.mu;
return p;
}
CFraction CFraction::operator /( CFraction &t)
{
CFraction p;
p.zi=zi*t.mu;
p.mu=mu*t.zi;
return p;
}
bool CFraction::operator >( CFraction &t)
{
int m;
int c;
int num1,num2;
m=mu*t.mu;
for(int i=2;i<m;i++)
{
if((i%mu==0)&&(i%t.mu==0))
{
c=i;
break;
}
}
num1=c/mu;
num2=c/t.mu;
if(zi*num1>t.zi*num2)
return true;
if(zi*num1<t.zi*num2)
return false;
}
bool CFraction::operator <( CFraction &t)
{
int m;
int c;
int num1,num2;
m=mu*t.mu;
for(int i=2;i<m;i++)
{
if((i%mu==0)&&(i%t.mu==0))
{
c=i;
break;
}
}
num1=c/mu;
num2=c/t.mu;
if(zi*num1<t.zi*num2)
return true;
if(zi*num1>t.zi*num2)
return false;
}
bool CFraction::operator <=( CFraction &t)
{
if(*this>t)
return false;
return true;
}
bool CFraction::operator >=( CFraction &t)
{
if(*this<t)
return false;
return true;
}
bool CFraction::operator ==( CFraction &t)
{
if(*this>t||*this<t)
return false;
return true;
}
bool CFraction::operator !=( CFraction &t)
{
if(*this==t)
return false;
return true;
}
int main()
{
CFraction n1(6,8),n2(4,12),n3;
cout<<"两个分数的相加"<<endl;
n3=n1+n2;
n3.simply();
n3.display();
cout<<"两个分数的相减"<<endl;
n3=n1-n2;
n3.simply();
n3.display();
cout<<"两个分数的相乘"<<endl;
n3=n1*n2;
n3.simply();
n3.display();
cout<<"两个分数的相除"<<endl;
n3=n1/n2;
n3.simply();
n3.display();
cout<<"下面进行的是两个分数的比较"<<endl;
if(n1>n2)
cout<<"n1>n2"<<endl;
if(n1<n2)
cout<<"n1<n2"<<endl;
if(n1==n2)
cout<<"n1=n2"<<endl;
if(n1!=n2)
cout<<"n1不等于n2"<<endl;
if(n1>=n2)
cout<<"n1等于或大于"<<endl;
if(n1<=n2)
cout<<"n1等于或小于m2"<<endl;
return 0;
}
运行结果:
心得体会;细心地编下去!!!