Procházet zdrojové kódy

Avoid large intermediate product in LCM

Mikhail Hogrefe před 7 roky
rodič
revize
56a029b20f
1 změnil soubory, kde provedl 1 přidání a 1 odebrání
  1. 1 1
      bigint/src/biguint.rs

+ 1 - 1
bigint/src/biguint.rs

@@ -955,7 +955,7 @@ impl Integer for BigUint {
     /// Calculates the Lowest Common Multiple (LCM) of the number and `other`.
     #[inline]
     fn lcm(&self, other: &BigUint) -> BigUint {
-        ((self * other) / self.gcd(other))
+        self / self.gcd(other) * other
     }
 
     /// Deprecated, use `is_multiple_of` instead.