shithub: MicroHs

ref: 08a727c87c4c642bfc3c609c295369f9d70c0d62
dir: /tests/Sieve.hs/

View raw version
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