问题及代码:
/*
* Copyright (c) 2014, 烟台大学计算机与控制工程学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:郝俊宇
* 完成日期:2015年 5 月9 日
* 版 本 号:v1.0
* 问题描述:在第八周项目三的基础上(1)定义分数的一目运算+和-,分别代表分数取正和求反,将“按位取反运算符”~重载为分数的求倒数运算。
* 输入描述:无
* 程序输出:对应的结果
*/
#include <iostream>
#include <cmath>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction(int nu=0,int de=1); //构造函数,初始化用
void simplify();//化简(使分子分母没有公因子)
CFraction operator+(const CFraction &c);
CFraction operator-(const CFraction &c);
CFraction operator*(const CFraction &c);
CFraction operator/(const CFraction &c);
CFraction operator+();
CFraction operator-();
CFraction operator~();
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 display();
};
CFraction::CFraction(int nu,int de)//构造函数,初始化使用
{
nume=nu;
deno=de;
}
void CFraction::simplify()//化简(使分子分母没有公因子)
{
int i,j,k,t;
i=(fabs(deno));
j=(fabs(nume));
if(i<j)
{
t=i;
i=j;
j=t;
}
while(k=i%j)
{
i=j;
j=k;
}
deno=deno/j;
nume=nume/j;
if(deno<0)
{
deno=-deno;
nume=-nume;
}
}
CFraction CFraction::operator+(const CFraction &c)
{
CFraction t;
t.deno=deno*c.deno;
t.nume=nume*c.deno+c.nume*deno;
t.simplify();
return t;
}
CFraction CFraction::operator-(const CFraction &c)
{
CFraction t;
t.deno=deno*c.deno;
t.nume=nume*c.deno-c.nume*deno;
t.simplify();
return t;
}
CFraction CFraction::operator*(const CFraction &c)
{
CFraction t;
t.deno=deno*c.deno;
t.nume=nume*c.nume;
t.simplify();
return t;
}
CFraction CFraction::operator/(const CFraction &c)
{
CFraction t;
t.deno=deno*c.nume;
t.nume=nume*c.deno;
t.simplify();
return t;
}
CFraction CFraction::operator+()
{
CFraction t;
t.deno=deno;
t.nume=nume;
t.simplify();
return t;
}
CFraction CFraction::operator-()
{
CFraction t;
t.deno=deno;
t.nume=-nume;
t.simplify();
return t;
}
CFraction CFraction::operator~()
{
CFraction t;
t.deno=nume;
t.nume=deno;
t.simplify();
return t;
}
bool CFraction::operator>(const CFraction &c)
{
int this_nume,c_nume;
this_nume=nume*c.deno;
c_nume=c.nume*deno;
if(this_nume>c_nume)
return true;
else
return false;
}
bool CFraction::operator<(const CFraction &c)
{
int this_nume,c_nume;
this_nume=nume*c.deno;
c_nume=c.nume*deno;
if(this_nume<c_nume)
return true;
else
return false;
}
bool CFraction::operator==(const CFraction &c)
{
if(*this!=c)
return false;
else
return true;
}
bool CFraction::operator!=(const CFraction &c)
{
if(*this>c||*this<c)
return true;
else
return false;
}
bool CFraction::operator>=(const CFraction &c)
{
if(*this<c)
return false;
else
return true;
}
bool CFraction::operator<=(const CFraction &c)
{
if(*this>c)
return false;
else
return true;
}
void CFraction::display()
{
cout<<nume<<"/"<<deno<<endl;
}
int main ()
{
CFraction t1(6,8),t2(4,5),t3;
cout<<"t1=";
t1.display();
cout<<"t2=";
t2.display();
t3=t1+t2;
cout<<"t1+t2=";
t3.display();
t3=t1-t2;
cout<<"t1-t2=";
t3.display();
t3=t1*t2;
cout<<"t1*t2=";
t3.display();
t3=t1/t2;
cout<<"t1/t2=";
t3.display();
t3=+t1;
cout<<"+t1=";
t3.display();
t3=-t2;
cout<<"-t2=";
t3.display();
t3=~t1;
cout<<"~t1=";
t3.display();
cout<<"比较大小:"<<endl;
if(t1>t2)
cout<<"t1>t2"<<endl;
if(t1<t2)
cout<<"t1<t2"<<endl;
if(t1==t2)
cout<<"t1=t2"<<endl;
if(t1!=t2)
cout<<"t1≠t2"<<endl;
if(t1>=t2)
cout<<"t1≥t2"<<endl;
if(t1<=t2)
cout<<"t1≤t2"<<endl;
return 0 ;
}
运行结果:
知识点总结:
分数类中运算符重载的应用
学习心得:
通过前两个项目的练习,感觉运算符重载已经挺简单的了。