/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2012, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:重载运算符(分数类)实现对象与整数运算
* 作 者: 刘镇
* 完成日期: 2012 年 4 月 7 日
* 版 本 号: 1.052
* 对任务及求解方法的描述部分
* 输入描述: ......
* 问题描述: 分数类的重载
* 程序输出: 分数
* 程序头部的注释结束
*/
#include<iostream>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
int gcd(int nu, int de);
public:
//构造函数及运算符重载的函数声明
CFraction(int nu = 0, int de = 1):nume(nu), deno(de){}; //构造函数,初始化用
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 - (CFraction &c);
friend CFraction operator + (CFraction &c, int s);
friend CFraction operator - (CFraction &c, int s);
friend CFraction operator * (CFraction &c, int s);
friend CFraction operator / (CFraction &c, int s);
friend CFraction operator + (int s, CFraction &c);
friend CFraction operator - (int s, CFraction &c);
friend CFraction operator * (int s, CFraction &c);
friend CFraction operator / (int s, CFraction &c);
bool operator > (CFraction &t);
bool operator < (CFraction &t);
bool operator >= (CFraction &t);
bool operator <= (CFraction &t);
bool operator == (CFraction &t);
bool operator != (CFraction &t);
void Simplify(); //化简(使分子分母没有公因子)
void display();
};
//重载函数的实现及用于测试的main()函数
void CFraction::Simplify()
{
int n ;
if(nume < 0)
{
n = gcd(-nume, deno);
}
else
{
n = gcd(nume, deno);
}
nume = nume / n;
deno = deno / n;
}
int CFraction::gcd(int nu, int de)
{
int t, r, a, b;
a = nu;
b = de;
if (a < b)
{
t = a;
a = b;
b = t;
}
while (b != 0)
{
r = a % b;
a = b;
b = r;
}
return a;
}
void CFraction::display()
{
cout << nume << "/" << deno << endl;
}
CFraction operator + (CFraction &c1,CFraction &c2)
{
CFraction c;
c.nume = c1.nume * c2.deno + c2.nume * c1.deno;
c.deno = c1.deno * c2.deno;
return c;
}
CFraction operator - (CFraction &c1,CFraction &c2)
{
CFraction c;
c.nume = c1.nume * c2.deno - c2.nume * c1.deno;
c.deno = c1.deno * c2.deno;
return c;
}
CFraction operator * (CFraction &c1,CFraction &c2)
{
CFraction c;
c.nume = c1.nume * c2.nume;
c.deno = c1.deno * c2.deno;
return c;
}
CFraction operator / (CFraction &c1,CFraction &c2)
{
CFraction c;
c.nume = c1.nume * c2.deno;
c.deno = c1.deno * c2.nume;
return c;
}
CFraction operator - (CFraction &c)
{
c.nume = 0 - c.nume;
return c;
}
bool CFraction::operator > (CFraction &t)
{
if(nume * t.deno > t.nume * deno)
{
return true;
}
else
{
return false;
}
}
bool CFraction::operator < (CFraction &t)
{
if(nume * t.deno < t.nume * deno)
{
return true;
}
else
{
return false;
}
}
bool CFraction::operator >= (CFraction &t)
{
if(nume * t.deno >= t.nume * deno)
{
return true;
}
else
{
return false;
}
}
bool CFraction::operator <= (CFraction &t)
{
if(nume * t.deno <= t.nume * deno)
{
return true;
}
else
{
return false;
}
}
bool CFraction::operator == (CFraction &t)
{
if(nume * t.deno == t.nume * deno)
{
return true;
}
else
{
return false;
}
}
bool CFraction::operator != (CFraction &t)
{
if(nume * t.deno != t.nume * deno)
{
return true;
}
else
{
return false;
}
}
CFraction operator + (CFraction &c, int s)
{
CFraction c2 = c;
c2.nume = c.nume + s * c.deno;
return c2;
}
CFraction operator - (CFraction &c, int s)
{
CFraction c2 = c;
c2.nume = c.nume - s * c.deno;
return c2;
}
CFraction operator * (CFraction &c, int s)
{
CFraction c2 = c;
c2.nume = c.nume * s;
return c2;
}
CFraction operator / (CFraction &c, int s)
{
CFraction c2 = c;
c2.deno = c.deno * s;
return c2;
}
CFraction operator + (int s, CFraction &c)
{
CFraction c2 = c;
c2.nume = c.nume + s * c.deno;
return c2;
}
CFraction operator - (int s, CFraction &c)
{
CFraction c2 = c;
c2.nume = s * c.deno - c.nume;
return c2;
}
CFraction operator * (int s, CFraction &c)
{
CFraction c2 = c;
c2.nume = s * c.nume;
return c2;
}
CFraction operator / (int s, CFraction &c)
{
CFraction c2 = c;
c2.nume = s * c.deno;
c2.deno = c.nume;
return c2;
}
void main()
{
CFraction c1(3, 5), c2(2, 3), c;
cout << "c1 =" ;
c1.Simplify();
c1.display();
cout << "c2 =" ;
c2.Simplify();
c2.display();
c = c1 + c2;
c.Simplify();
cout << "c1 + c2 =";
c.display();
c = c1 - c2;
c.Simplify();
cout << "c1 - c2 =";
c.display();
c = c1 * c2;
c.Simplify();
cout << "c1 * c2 =";
c.display();
c = c1 / c2;
c.Simplify();
cout << "c1 / c2 =";
c.display();
c = c1 + 2;
cout << "c1 + 2 =";
c.Simplify();
c.display();
c = 2 - c2;
cout << "2 - c2 =";
c.Simplify();
c.display();
c = c1 * 2;
cout << "c1 * 2 =";
c.Simplify();
c.display();
c = 2 / c2;
cout << "2 / c2 =";
c.Simplify();
c.display();
c = - c1;
cout << "-c1 =";
c.display();
if(c1 > c2)
{
cout << "c1 > c2" << endl;
}
if(c1 < c2)
{
cout << "c1 < c2" << endl;
}
if(c1 >= c2)
{
cout << "c1 ≥ c2" << endl;
}
if(c1 <= c2)
{
cout << "c1 ≤ c2" << endl;
}
if(c1 == c2)
{
cout << "c1 = c2" << endl;
}
if(c1 != c2)
{
cout << "c1 ≠ c2" << endl;
}
system("pause");
}
运行结果: