Quellcode durchsuchen

Improve the divider compution with square root limit

DricomDragon vor 5 Jahren
Ursprung
Commit
abad83c71f
1 geänderte Dateien mit 1 neuen und 1 gelöschten Zeilen
  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)]