1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
|
#include "Ratio.h"
namespace Sexy
{
Ratio::Ratio()
: mNumerator(1)
, mDenominator(1)
{
}
Ratio::Ratio(int theNumerator, int theDenominator)
{
Set(theNumerator, theDenominator);
}
void Ratio::Set(int theNumerator, int theDenominator)
{
// find the greatest-common-denominator of theNumerator and theDenominator.
int t;
int a = theNumerator;
int b = theDenominator;
while (b != 0)
{
t = b;
b = a % b;
a = t;
}
// divide by the g-c-d to reduce mNumerator/mDenominator to lowest terms.
mNumerator = theNumerator/a;
mDenominator = theDenominator/a;
}
}
|