Skip to content

Commit 63bc09f

Browse files
committed
Unique pairs
1 parent c35e3a9 commit 63bc09f

File tree

1 file changed

+57
-0
lines changed

1 file changed

+57
-0
lines changed

exercise_2.40.exs

Lines changed: 57 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,57 @@
1+
defmodule UniquePairs do
2+
def of(n) when n < 2, do: []
3+
4+
def of(n) do
5+
Enum.flat_map(2..n, fn(i) ->
6+
Enum.map(1..(i-1), fn(j) -> [i, j] end)
7+
end)
8+
end
9+
end
10+
11+
defmodule PrimeSumPairs do
12+
def of(n) when n < 2, do: []
13+
14+
def of(n) do
15+
Enum.filter(UniquePairs.of(n), &prime_sum?/1)
16+
end
17+
18+
defp prime_sum?(pair) do
19+
i = hd pair
20+
j = hd tl pair
21+
PrimeChecker.is_prime?(i + j)
22+
end
23+
end
24+
25+
defmodule PrimeChecker do
26+
def is_prime?(n), do: n == smallest(n)
27+
28+
defp smallest(n), do: find(n, 2)
29+
30+
defp find(n, test) when test * test > n, do: n
31+
defp find(n, test) when rem(n, test) == 0, do: test
32+
defp find(n, test), do: find(n, test + 1)
33+
end
34+
35+
36+
ExUnit.start
37+
38+
defmodule UniquePairsTests do
39+
use ExUnit.Case, async: true
40+
41+
test "no pairs when n is 1" do
42+
assert UniquePairs.of(1) == []
43+
end
44+
45+
test "generates all pairs" do
46+
assert UniquePairs.of(3) == [[2, 1], [3, 1], [3, 2]]
47+
end
48+
end
49+
50+
defmodule PrimeSumPairsTests do
51+
use ExUnit.Case, async: true
52+
53+
test "it generates the expected pairs" do
54+
assert PrimeSumPairs.of(6) == [[2, 1], [3, 2], [4, 1], [4, 3], [5, 2], [6, 1], [6, 5]]
55+
end
56+
end
57+

0 commit comments

Comments
 (0)