ref: 48a34d1eb8df3def243689c0c5be2d5b3000a90c
dir: /tests/Sieve.hs/
module Sieve(main) where
import Prelude
primes :: [Integer]
primes =
sieve (from 2)
where
from n = n : from (n + 1)
sieve (p : x) = p : sieve (filter x)
where
filter (n : x) =
if n `rem` p == 0 then filter x
else n : filter x
main :: IO ()
main =
print $ take 100 primes