Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
Solved

# Need math function (or algorithm) for reducing fractions

Posted on 1998-04-19
Medium Priority
404 Views
I need to find a C++ math library function for reducing fractions, but have not been able to find one. Is there one available? If not, can you help me with an algortihm to do this i.e. how to get an answer of 3/5 when the input was 6/10?
0
Question by:englm
[X]
###### Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

• Help others & share knowledge
• Earn cash & points
• 5
• 4

LVL 3

Accepted Solution

q2guo earned 150 total points
ID: 1162143
The following function is not the most efficient funciton for doing fraction reduction.  But its the only one I can come
up with in 2 minutes.

The argument d and n represent denominator and neminator respectively.

void Reduce(int &d, int &n) {
for (int i = n/2; i > 1; i--) {
if ( (n%i) == 0) {
if ( (d%i) == 0) {
n = n / i;
d = d / i;
break;
}
}
}
}
0

LVL 84

Expert Comment

ID: 1162144
//Heres one Euclid came up with over 2 millennia ago
int gcd(int a,int b){
while( b ){
int c;
c = a%b;
a = b;
b = c;
}
return a;
}

main(int argc,char *argv[]){
int d,n,f;
d = atoi(argv[1]);
n = atoi(argv[2]);
f = gcd(d,n);
printf("%d/%d\n",d/f,n/f);
}

0

LVL 84

Expert Comment

ID: 1162145
(If n was supposed to represent the numerator, I think I got my variable names backwards)

But it looks like Reduce(4,4) will only reduce to 2/2
and Reduce(4,-4) seems to have an even worse problem.
0

LVL 2

Expert Comment

ID: 1162146
Why (q2guo) do you start at n/2? Shouldn't you check to see which is heigher?  What if the fraction is 10/2.? It will return 10/2 which can be 5/1...
0

LVL 3

Expert Comment

ID: 1162147
Ready4Dis, I assumed that the fraction is a pure one, meaning that the numerator is always smaller that the denominator.
0

LVL 84

Expert Comment

ID: 1162148
Then if n is assumed to be smaller than d, shouldn't you have started with d/2?
(I think that's what confused my labels:-) fortunately, the gcd approach doesn't depend such assumptions.
0

LVL 3

Expert Comment

ID: 1162149
ozo: why would you start with d/2?  Since n is smaller than d
all i(s) between d/2 and n/2 are just extra work.
0

LVL 84

Expert Comment

ID: 1162150
Given a fraction like 2/10, with the numerator 2 smaller than the denominator 10,
starting i=n/2 i.e. i=1 will fail to reduce it to 1/5
(with a fraction like 10/2, since n=10 and d=2, i=n/2 would start at 5, so Reduce(2,10) would find (10/2)/(2/2) = 5/1)

0

LVL 3

Expert Comment

ID: 1162151
Ok, here is the function again

void Reduce(int &d, int &n) {
int temp = (d >= n ? d : n);
for (int i = temp; i > 1; i--) {
if ( (n%i) == 0) {
if ( (d%i) == 0) {
n = n / i;
d = d / i;
break;
}
}
}
}
0

LVL 84

Expert Comment

ID: 1162152
Still has a problem with -10/2
Here's my (Euclid's) function again with the variables renamed:

int gcd(int a,int b){
while( b ){
int c = a%b;
a = b;
b = c;
}
return a;
}

main(int argc,char *argv[]){
int n,d,i;
n = atoi(argv[1]);
d = atoi(argv[2]);
i = gcd(n,d);
printf("%d/%d\n",n/i,d/i);
}

0

## Featured Post

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Often, when implementing a feature, you won't know how certain events should be handled at the point where they occur and you'd rather defer to the user of your function or class. For example, a XML parser will extract a tag from the source code, whâ€¦
Basic understanding on "OO- Object Orientation" is needed for designing a logical solution to solve a problem. Basic OOAD is a prerequisite for a coder to ensure that they follow the basic design of OO. This would help developers to understand the bâ€¦
The goal of the video will be to teach the user the concept of local variables and scope. An example of a locally defined variable will be given as well as an explanation of what scope is in C++. The local variable and concept of scope will be relatâ€¦
The viewer will be introduced to the technique of using vectors in C++. The video will cover how to define a vector, store values in the vector and retrieve data from the values stored in the vector.
###### Suggested Courses
Course of the Month9 days, 20 hours left to enroll