Explorar o código

Improve the divider compution with square root limit

DricomDragon %!s(int64=5) %!d(string=hai) anos
pai
achega
abad83c71f
Modificáronse 1 ficheiros con 1 adicións e 1 borrados
  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)]