#include <iostream>
#include <string>
#include <stdlib.h>
class Rational
{
public:
Rational(int num, int denom);//num 分子,denom 分母
Rational operator+(Rational rhs);//rhs == right hand side
Rational operator-(Rational rhs);
Rational operator*(Rational rhs);
Rational operator/(Rational rhs);
void print();
private:
void normalize(); //负责对分数的简化处理
int numerator; //分子
int denominator; //分母
};
Rational::Rational(int num, int denom)
{
numerator = num;
denominator = denom;
normalize();
}
void Rational::normalize()
{
if (denominator < 0)
{
numerator = -numerator;
denominator = -denominator;
}
//欧里几德算法,分子分母除以最大公约数化简。
int a = abs(numerator);
int b = abs(denominator);
while (b>0)
{
int t = a%b;
a = b;
b = t;
}
numerator /= a;
denominator /= a;
}
Rational Rational::operator+(Rational rhs)
{
int a = numerator;
int b = denominator;
int c = rhs.numerator;
int d = rhs.denominator;
int e = a*b + c*d;
int f = b*d;
return Rational(e,f);
}
Rational Rational::operator-(Rational rhs)
{
rhs.numerator = -rhs.numerator;
return operator+(rhs);
}
Rational Rational::operator*(Rational rhs)
{
int a = numerator;
int b = denominator;
int c = rhs.numerator;
int d = rhs.denominator;
int e = a*c;
int f = b*d;
return Rational(e,f);
}
Rational Rational::operator/(Rational rhs)
{
int t = rhs.numerator;
rhs.numerator = rhs.denominator;
rhs.denominator = t;
return operator*(rhs);
}
void Rational::print()
{
if(numerator%denominator == 0)
std::cout << numerator / denominator;
else
std::cout << numerator << "/" << denominator;
}
int main()
{
Rational f1(2,16);
Rational f2(7,8);
Rational res = f1 + f2;
f1.print();
std::cout<<" + ";
f2.print();
std::cout<<" = ";
res.print();
std::cout<<"\n";
res = f1 - f2;
f1.print();
std::cout<<" - ";
f2.print();
std::cout<<" = ";
res.print();
std::cout<<"\n";
res = f1 * f2;
f1.print();
std::cout<<" * ";
f2.print();
std::cout<<" = ";
res.print();
std::cout<<"\n";
res = f1 / f2;
f1.print();
std::cout<<" / ";
f2.print();
std::cout<<" = ";
res.print();
std::cout<<"\n";
}