diff options
author | William Carroll <wpcarro@gmail.com> | 2020-12-11T22·43+0000 |
---|---|---|
committer | William Carroll <wpcarro@gmail.com> | 2020-12-11T22·43+0000 |
commit | f1e458239266dac1d18120c6c3b092a67a739577 (patch) | |
tree | 87874e3b4c8a3a7d681fd3995c4fcb80e5652600 /assessments/semiprimes/server/lib | |
parent | 6af5e4b82e9d2f025ad388f82495865a195c5218 (diff) |
Define Math module
Support `Math.factor` and cover it with tests.
Diffstat (limited to 'assessments/semiprimes/server/lib')
-rw-r--r-- | assessments/semiprimes/server/lib/math.ex | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/assessments/semiprimes/server/lib/math.ex b/assessments/semiprimes/server/lib/math.ex new file mode 100644 index 000000000000..8a33be475389 --- /dev/null +++ b/assessments/semiprimes/server/lib/math.ex @@ -0,0 +1,26 @@ +defmodule Math do + @moduledoc """ + Math utilities. + """ + alias Extras + + @doc """ + Returns the prime factors for `n`. + + ## Examples + + iex> Math.factor(15) + [3, 5] + + """ + def factor(1), do: [] + + def factor(n) do + Extras.range(2, n - 1) + |> Enum.find(&(rem(n, &1) == 0)) + |> case do + nil -> [n] + x -> [x | factor(div(n, x))] + end + end +end |