问题及代码:
/*
*Copyright (c)2015,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:project.cpp
*作 者:陈文青
*完成日期:2015年5月9日
*版 本 号:v1.0
*
*问题描述:实现分数类中的运算符重载,在分数类中可以完成分数的加减乘除(运算后再化简)、
比较(6种关系)的运算。可以在第4周分数类代码的基础上开始工作。
*程序输入:
*程序输出:
*/
#include <iostream>
#include <Cmath>
using namespace std;
int gcd(int, int);
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction(int nu=0,int de=1):nume(nu),deno(de) {}
void display();
void simplify();
//输入输出的重载
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 CFraction::display()
{
cout<<nume<<"/"<<deno<<endl;
}
// 分数化简
void CFraction::simplify()
{
int n=nume,d=deno;
int r=gcd(n,d);//r为nume和deno的最大公约数
deno/=r; // 化简
nume/=r;
if (deno<0) // 将分母转化为正数
{
deno=-deno;
nume=-nume;
}
}
// 分数相加
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;
t.nume=nume*c.deno;
t.deno=deno*c.nume;
t.simplify();
return t;
}
// 分数比较大小
bool CFraction::operator>(const CFraction &c)
{
CFraction t=*this-c;
t.simplify();
if(nume>0)
return true;
else
return false;
}
// 分数比较大小
bool CFraction::operator<(const CFraction &c)
{
CFraction t=*this-c;
t.simplify();
if(nume<0)
return true;
else
return false;
}
// 分数比较大小
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;
}
// 分数比较大小
bool CFraction::operator<=(const CFraction &c)
{
if (*this>c) return false;
return true;
}
//求最大公约数;
int gcd(int x,int y)
{
int i;
while(y>0)
{
i=x%y;
x=y;
y=i;
}
return x;
}
int main()
{
CFraction x(4,5),y(3,4);
cout<<"x=";
x.display();
cout<<"y=";
y.display();
cout<<"x+y=";
(x+y).display();
cout<<"x-y=";
(x-y).display();
cout<<"x*y=";
(x*y).display();
cout<<"x/y=";
(x/y).display();
if(x>y)
cout<<"x>y"<<endl;
if(x<y)
cout<<"x<y"<<endl;
if(x==y)
cout<<"x=y"<<endl;
if(x!=y)
cout<<"x!=y"<<endl;
return 0;
}
运行结果:
知识点总结:
分数类中的运算符重载
学习心得:
如上文注释