blob: 059085dfaafacdc16c8e7d5d4ff56153c3aca061 (
plain)
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;
}
}
|