logo

Steinin algoritmi GCD:n löytämiseksi

Kokeile sitä GfG Practicessa ' title=

Steinin algoritmi tai binäärinen GCD-algoritmi on algoritmi, joka laskee kahden ei-negatiivisen kokonaisluvun suurimman yhteisen jakajan. Steinin algoritmi korvaa jaon aritmeettisilla siirtovertailuilla ja vähennyksillä.

Esimerkkejä:  



Syöte : a = 17 b = 34
Lähtö : 17

Syöte : a = 50 b = 49
Lähtö : 1

Algoritmi GCD:n löytämiseksi käyttämällä Steinin algoritmia gcd(a b)  

Algoritmi on pääasiassa optimointia standardiin nähden Euklidinen algoritmi GCD:lle



  1. Jos sekä a että b ovat 0, gcd on nolla gcd(0 0) = 0.
  2. gcd(a 0) = a ja gcd(0 b) = b, koska kaikki jakaa 0:n.
  3. Jos a ja b ovat molemmat parillisia gcd(a b) = 2*gcd(a/2 b/2), koska 2 on yhteinen jakaja. Kertominen kahdella voidaan tehdä bittisuuntaisella siirtooperaattorilla.
  4. Jos a on parillinen ja b on pariton gcd(a b) = gcd(a/2 b). Vastaavasti jos a on pariton ja b on parillinen 
    gcd(a b) = gcd(a b/2). Tämä johtuu siitä, että 2 ei ole yhteinen jakaja.
  5. Jos sekä a että b ovat parittomia, niin gcd(a b) = gcd(|a-b|/2 b). Huomaa, että kahden parittoman luvun ero on parillinen
  6. Toista vaiheet 3–5, kunnes a = b tai kunnes a = 0. Kummassakin tapauksessa GCD on potenssi(2 k) * b, jossa teho(2 k) on 2 korotus k:n potenssiin ja k on vaiheessa 3 löydetty 2:n yhteisten kertoimien lukumäärä.
C++
// Iterative C++ program to // implement Stein's Algorithm #include    using namespace std; // Function to implement // Stein's Algorithm int gcd(int a int b) {  /* GCD(0 b) == b; GCD(a 0) == a  GCD(0 0) == 0 */  if (a == 0)  return b;  if (b == 0)  return a;  /*Finding K where K is the  greatest power of 2  that divides both a and b. */  int k;  for (k = 0; ((a | b) & 1) == 0; ++k)   {  a >>= 1;  b >>= 1;  }  /* Dividing a by 2 until a becomes odd */  while ((a & 1) == 0)  a >>= 1;  /* From here on 'a' is always odd. */  do  {  /* If b is even remove all factor of 2 in b */  while ((b & 1) == 0)  b >>= 1;  /* Now a and b are both odd.  Swap if necessary so a <= b  then set b = b - a (which is even).*/  if (a > b)  swap(a b); // Swap u and v.  b = (b - a);  }while (b != 0);  /* restore common factors of 2 */  return a << k; } // Driver code int main() {  int a = 34 b = 17;  printf('Gcd of given numbers is %dn' gcd(a b));  return 0; } 
Java
// Iterative Java program to // implement Stein's Algorithm import java.io.*; class GFG {  // Function to implement Stein's  // Algorithm  static int gcd(int a int b)  {  // GCD(0 b) == b; GCD(a 0) == a  // GCD(0 0) == 0  if (a == 0)  return b;  if (b == 0)  return a;  // Finding K where K is the greatest  // power of 2 that divides both a and b  int k;  for (k = 0; ((a | b) & 1) == 0; ++k)   {  a >>= 1;  b >>= 1;  }  // Dividing a by 2 until a becomes odd  while ((a & 1) == 0)  a >>= 1;  // From here on 'a' is always odd.  do   {  // If b is even remove  // all factor of 2 in b  while ((b & 1) == 0)  b >>= 1;  // Now a and b are both odd. Swap  // if necessary so a <= b then set  // b = b - a (which is even)  if (a > b)   {  // Swap u and v.  int temp = a;  a = b;  b = temp;  }  b = (b - a);  } while (b != 0);  // restore common factors of 2  return a << k;  }  // Driver code  public static void main(String args[])  {  int a = 34 b = 17;  System.out.println('Gcd of given '  + 'numbers is ' + gcd(a b));  } } // This code is contributed by Nikita Tiwari 
Python
# Iterative Python 3 program to # implement Stein's Algorithm # Function to implement # Stein's Algorithm def gcd(a b): # GCD(0 b) == b; GCD(a 0) == a # GCD(0 0) == 0 if (a == 0): return b if (b == 0): return a # Finding K where K is the # greatest power of 2 that # divides both a and b. k = 0 while(((a | b) & 1) == 0): a = a >> 1 b = b >> 1 k = k + 1 # Dividing a by 2 until a becomes odd while ((a & 1) == 0): a = a >> 1 # From here on 'a' is always odd. while(b != 0): # If b is even remove all # factor of 2 in b while ((b & 1) == 0): b = b >> 1 # Now a and b are both odd. Swap if # necessary so a <= b then set # b = b - a (which is even). if (a > b): # Swap u and v. temp = a a = b b = temp b = (b - a) # restore common factors of 2 return (a << k) # Driver code a = 34 b = 17 print('Gcd of given numbers is ' gcd(a b)) # This code is contributed by Nikita Tiwari. 
C#
// Iterative C# program to implement // Stein's Algorithm using System; class GFG {  // Function to implement Stein's  // Algorithm  static int gcd(int a int b)  {  // GCD(0 b) == b; GCD(a 0) == a  // GCD(0 0) == 0  if (a == 0)  return b;  if (b == 0)  return a;  // Finding K where K is the greatest  // power of 2 that divides both a and b  int k;  for (k = 0; ((a | b) & 1) == 0; ++k)   {  a >>= 1;  b >>= 1;  }  // Dividing a by 2 until a becomes odd  while ((a & 1) == 0)  a >>= 1;  // From here on 'a' is always odd  do   {  // If b is even remove  // all factor of 2 in b  while ((b & 1) == 0)  b >>= 1;  /* Now a and b are both odd. Swap  if necessary so a <= b then set  b = b - a (which is even).*/  if (a > b) {  // Swap u and v.  int temp = a;  a = b;  b = temp;  }  b = (b - a);  } while (b != 0);  /* restore common factors of 2 */  return a << k;  }  // Driver code  public static void Main()  {  int a = 34 b = 17;  Console.Write('Gcd of given '  + 'numbers is ' + gcd(a b));  } } // This code is contributed by nitin mittal 
JavaScript
<script> // Iterative JavaScript program to // implement Stein's Algorithm // Function to implement // Stein's Algorithm function gcd( a b) {  /* GCD(0 b) == b; GCD(a 0) == a  GCD(0 0) == 0 */  if (a == 0)  return b;  if (b == 0)  return a;  /*Finding K where K is the  greatest power of 2  that divides both a and b. */  let k;  for (k = 0; ((a | b) & 1) == 0; ++k)   {  a >>= 1;  b >>= 1;  }  /* Dividing a by 2 until a becomes odd */  while ((a & 1) == 0)  a >>= 1;  /* From here on 'a' is always odd. */  do  {  /* If b is even remove all factor of 2 in b */  while ((b & 1) == 0)  b >>= 1;  /* Now a and b are both odd.  Swap if necessary so a <= b  then set b = b - a (which is even).*/  if (a > b){  let t = a;  a = b;  b = t;  }  b = (b - a);  }while (b != 0);  /* restore common factors of 2 */  return a << k; } // Driver code  let a = 34 b = 17;  document.write('Gcd of given numbers is '+ gcd(a b)); // This code contributed by gauravrajput1  </script> 
PHP
 // Iterative php program to  // implement Stein's Algorithm // Function to implement  // Stein's Algorithm function gcd($a $b) { // GCD(0 b) == b; GCD(a 0) == a // GCD(0 0) == 0 if ($a == 0) return $b; if ($b == 0) return $a; // Finding K where K is the greatest // power of 2 that divides both a and b. $k; for ($k = 0; (($a | $b) & 1) == 0; ++$k) { $a >>= 1; $b >>= 1; } // Dividing a by 2 until a becomes odd  while (($a & 1) == 0) $a >>= 1; // From here on 'a' is always odd. do { // If b is even remove  // all factor of 2 in b  while (($b & 1) == 0) $b >>= 1; // Now a and b are both odd. Swap // if necessary so a <= b then set  // b = b - a (which is even) if ($a > $b) swap($a $b); // Swap u and v. $b = ($b - $a); } while ($b != 0); // restore common factors of 2 return $a << $k; } // Driver code $a = 34; $b = 17; echo 'Gcd of given numbers is ' . gcd($a $b); // This code is contributed by ajit ?> 

Lähtö
Gcd of given numbers is 17

Aika monimutkaisuus: O(N*N)
Aputila: O(1)

[Odotettu lähestymistapa 2] Rekursiivinen toteutus - O(N*N) Aika ja O(N*N) Avaruus

C++
// Recursive C++ program to // implement Stein's Algorithm #include    using namespace std; // Function to implement // Stein's Algorithm int gcd(int a int b) {  if (a == b)  return a;  // GCD(0 b) == b; GCD(a 0) == a  // GCD(0 0) == 0  if (a == 0)  return b;  if (b == 0)  return a;  // look for factors of 2  if (~a & 1) // a is even  {  if (b & 1) // b is odd  return gcd(a >> 1 b);  else // both a and b are even  return gcd(a >> 1 b >> 1) << 1;  }  if (~b & 1) // a is odd b is even  return gcd(a b >> 1);  // reduce larger number  if (a > b)  return gcd((a - b) >> 1 b);  return gcd((b - a) >> 1 a); } // Driver code int main() {  int a = 34 b = 17;  printf('Gcd of given numbers is %dn' gcd(a b));  return 0; } 
Java
// Recursive Java program to // implement Stein's Algorithm import java.io.*; class GFG {  // Function to implement  // Stein's Algorithm  static int gcd(int a int b)  {  if (a == b)  return a;  // GCD(0 b) == b; GCD(a 0) == a  // GCD(0 0) == 0  if (a == 0)  return b;  if (b == 0)  return a;  // look for factors of 2  if ((~a & 1) == 1) // a is even  {  if ((b & 1) == 1) // b is odd  return gcd(a >> 1 b);  else // both a and b are even  return gcd(a >> 1 b >> 1) << 1;  }  // a is odd b is even  if ((~b & 1) == 1)  return gcd(a b >> 1);  // reduce larger number  if (a > b)  return gcd((a - b) >> 1 b);  return gcd((b - a) >> 1 a);  }  // Driver code  public static void main(String args[])  {  int a = 34 b = 17;  System.out.println('Gcd of given'  + 'numbers is ' + gcd(a b));  } } // This code is contributed by Nikita Tiwari 
Python
# Recursive Python 3 program to # implement Stein's Algorithm # Function to implement # Stein's Algorithm def gcd(a b): if (a == b): return a # GCD(0 b) == b; GCD(a 0) == a # GCD(0 0) == 0 if (a == 0): return b if (b == 0): return a # look for factors of 2 # a is even if ((~a & 1) == 1): # b is odd if ((b & 1) == 1): return gcd(a >> 1 b) else: # both a and b are even return (gcd(a >> 1 b >> 1) << 1) # a is odd b is even if ((~b & 1) == 1): return gcd(a b >> 1) # reduce larger number if (a > b): return gcd((a - b) >> 1 b) return gcd((b - a) >> 1 a) # Driver code a b = 34 17 print('Gcd of given numbers is ' gcd(a b)) # This code is contributed # by Nikita Tiwari. 
C#
// Recursive C# program to // implement Stein's Algorithm using System; class GFG {  // Function to implement  // Stein's Algorithm  static int gcd(int a int b)  {  if (a == b)  return a;  // GCD(0 b) == b;  // GCD(a 0) == a  // GCD(0 0) == 0  if (a == 0)  return b;  if (b == 0)  return a;  // look for factors of 2  // a is even  if ((~a & 1) == 1) {  // b is odd  if ((b & 1) == 1)  return gcd(a >> 1 b);  else  // both a and b are even  return gcd(a >> 1 b >> 1) << 1;  }  // a is odd b is even  if ((~b & 1) == 1)  return gcd(a b >> 1);  // reduce larger number  if (a > b)  return gcd((a - b) >> 1 b);  return gcd((b - a) >> 1 a);  }  // Driver code  public static void Main()  {  int a = 34 b = 17;  Console.Write('Gcd of given'  + 'numbers is ' + gcd(a b));  } } // This code is contributed by nitin mittal. 
JavaScript
<script> // JavaScript program to // implement Stein's Algorithm  // Function to implement  // Stein's Algorithm  function gcd(a b)  {  if (a == b)  return a;    // GCD(0 b) == b; GCD(a 0) == a  // GCD(0 0) == 0  if (a == 0)  return b;  if (b == 0)  return a;    // look for factors of 2  if ((~a & 1) == 1) // a is even  {  if ((b & 1) == 1) // b is odd  return gcd(a >> 1 b);    else // both a and b are even  return gcd(a >> 1 b >> 1) << 1;  }    // a is odd b is even  if ((~b & 1) == 1)  return gcd(a b >> 1);    // reduce larger number  if (a > b)  return gcd((a - b) >> 1 b);    return gcd((b - a) >> 1 a);  } // Driver Code  let a = 34 b = 17;  document.write('Gcd of given '  + 'numbers is ' + gcd(a b));   </script> 
PHP
 // Recursive PHP program to // implement Stein's Algorithm // Function to implement // Stein's Algorithm function gcd($a $b) { if ($a == $b) return $a; /* GCD(0 b) == b; GCD(a 0) == a  GCD(0 0) == 0 */ if ($a == 0) return $b; if ($b == 0) return $a; // look for factors of 2 if (~$a & 1) // a is even { if ($b & 1) // b is odd return gcd($a >> 1 $b); else // both a and b are even return gcd($a >> 1 $b >> 1) << 1; } if (~$b & 1) // a is odd b is even return gcd($a $b >> 1); // reduce larger number if ($a > $b) return gcd(($a - $b) >> 1 $b); return gcd(($b - $a) >> 1 $a); } // Driver code $a = 34; $b = 17; echo 'Gcd of given numbers is: ' gcd($a $b); // This code is contributed by aj_36 ?> 

Lähtö
Gcd of given numbers is 17

Aika monimutkaisuus : O(N*N) missä N on suuremman luvun bittien määrä.
Aputila: O(N*N) missä N on suuremman luvun bittien lukumäärä.

Saatat myös pitää - Perus- ja laajennettu euklidinen algoritmi

Edut Euclidin GCD-algoritmiin verrattuna

  • Steinin algoritmi on optimoitu versio Euclidin GCD-algoritmista.
  • se on tehokkaampaa bitwise shift -operaattorilla.