-
Notifications
You must be signed in to change notification settings - Fork 32
/
ex02.ex
64 lines (47 loc) · 1.84 KB
/
ex02.ex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
ExUnit.start
Code.load_file "support.ex"
defmodule Ex02 do
use ExUnit.Case
import Support
##############################################################################
# 2: 3 questions, 15 points available
##############################################################################
# These exercises manipulate lists using anonymous functions.
# Replace the text
#
# your_anonymous_function(...)
#
# with your solution. Note that even though the placeholder
# takes just one line, your solution may take several.
#
# You can test your answers by running:
#
# elixir ex02.ex
##################
# 2.1: 5 points #
########################################################################
# Write an anonymous function that takes two numbers and returns a two #
# element list. The first element of the list will be the sum of the #
# numbers, and second should be the difference #
########################################################################
list2a = your_anonymous_function(1, 2)
assert list2a.(1, 2) == [ 3, -1 ]
assert list2a.(-1, 100) == [ 99, -101 ]
##################
# 2.2: 5 points #
##################################
# Do the same using the & syntax #
##################################
list2b = your_anonymous_function(1, 2)
assert list2b.(1, 2) == [ 3, -1 ]
assert list2b.(-1, 100) == [ 99, -101 ]
##################
# 2.3: 5 points #
################################################################
# Write a function that uses pattern matching to return true #
# if the first two elements of a list are equal #
################################################################
first2equal = your_anonymous_function([])
assert first2equal.([4, 4, 5, 6, 7])
assert !first2equal.([4, 5, 6, 7, 8])
end