Gcd Algorithm with JavaScript

  Pi Ke        2011-09-21 15:57:32       11,154        2         

How to find the greatest common divisor between two integers? We may encounter this problem frequently in interviews or other occasions.

An efficient metho to find gcd is the Euclidean algorithm, which uses the division algorithm in combination with the observation that the gcd of two numbers also divides their difference: divide 48 by 18 to get a quotient of 2 and a remainder of 12. Then divide 18 by 12 to get a quotient of 1 and a remainder of 6. Then divide 12 by 6 to get a remainder of 0, which means that 6 is the gcd. Formally, it could be written as

gcd(a,0) = a

gcd(a,b) = gcd(b,a mod b)

 The code can be shown below;

function gcd(a,b){

            if(b==0){

                        return a;

            }else{

                        return gcd(b,a%b);

            }

}

 

JAVASCRIPT  ALGORITHM  GCD  IMPLEMENTATION 

       

  RELATED


  2 COMMENTS


Someone2841 [Reply]@ 2012-12-06 15:52:33
This function is recursive.. would not looping be better? For example: function gcd(a,b){ if(a%1!=0||b%1!=0) return -1; //Return -1 if a or b are not integers while(b!=0){var c = a%b; a=b; b=c;} //The algorithm return a; }
Someone2841 [Reply]@ 2012-12-06 15:54:05
/*Code with \\ representing line breaks:*/ \\ function gcd(a,b){ \\ if(a%1!=0||b%1!=0) return -1; //Return -1 if a or b are not integers \\ while(b!=0){var c = a%b; a=b; b=c;} //The algorithm \\ return a; \\ }


  RANDOM FUN

I am a programmer

A man was smoking when a lady walked by and chided him, "don't you know these things are bad for you? Look at the warning on the box". The man replied, "it's OK lady, I'm a programmer". The lady asked,"what the hell does that have to do with this?" The man said, "programmers only care about errors,