Procházet zdrojové kódy

Improve the divider compution with square root limit

DricomDragon před 5 roky
rodič
revize
abad83c71f
1 změnil soubory, kde provedl 1 přidání a 1 odebrání
  1. 1 1
      prime.hs

+ 1 - 1
prime.hs

@@ -1,6 +1,6 @@
 -- Exercice from slide 42/82
 
-dividers n = [k | k <- [2..(n-1)], rem n k == 0]
+dividers n = [k | k <- takeWhile (\k -> k * k <= n) [2..n], rem n k == 0]
 dividersf n = filter (\k -> rem n k == 0) [2..(n-1)]
 
 primer n = [i | i <- [2..(n-1)], null (dividers i)]