Trying to write a program to implement Euler's Algorithm????

1 view (last 30 days)
I am trying to write a program to implement Euler's algorithm. I know that the greatest common divisor of (a,b,c) = gcd(gcd(a,b),c). I also want to write another program to compute the gcd of three natural numbers. I am having trouble doing this though. Here is what I know, that a = b*(quotient q) + remainder(r), where a>b and b>r, so that to find the gcd(a,b) I could replace a and b by b and r and repeat the process. The successive remainders get smaller until I eventually get r = 0. I just simply am confused on how to go about writing a program for this.
  4 Comments
Reelz
Reelz on 23 Apr 2012
I have the code down, but now I am trying to compute three outputs, I keep running into trouble though. Help please?
clear; clc
% input, take only positive numbers into account
a = input('First number: ');
b = input('Second number: ');
c = input('Third number: ');
a = abs(a);
b = abs(b);
c= abs(c);
r = a - b*floor(a/b);
% Repeat the operation till updates of a = # of update b
while r ~= 0
a > b;
a = b;
b = r;
r = a - b*floor(a/b);
end
% Show result
GCD = b
Geoff
Geoff on 23 Apr 2012
Eh?? What are the other two outputs. I understand you want to compute GCD(a,b,c). Is that correct? If so, read my last comment. Make a function to compute GCD of two numbers. I don't see any function definitions in your code.

Sign in to comment.

Answers (1)

Geoff
Geoff on 18 Apr 2012
Have you considered doing a google for the Euclidean Algorithm?
Try the very first search result =P
Halfway down the page, there's very concise pseudocode.

Categories

Find more on Function Creation in Help Center and File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!