Skip to content

Instantly share code, notes, and snippets.

@neodevelop
Created December 7, 2016 23:17
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save neodevelop/aaf941b6bc809fb0074f9b17dc0eef22 to your computer and use it in GitHub Desktop.
Save neodevelop/aaf941b6bc809fb0074f9b17dc0eef22 to your computer and use it in GitHub Desktop.
defmodule Sieve.Eratosthenes do
def primes_to(n) do
sieve([], candidates(n))
end
defp sieve(primes, []) do
primes
end
defp sieve(primes, [h | t]) do
sieve(primes ++ [h], reject_numbers(h, t))
end
def candidates(n) do
Enum.into 2..n, []
end
def reject_numbers(factor, numbers) do
Enum.reject numbers, fn x -> rem(x,factor) == 0 end
end
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment