-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathmy_list.exs
More file actions
147 lines (108 loc) · 4.04 KB
/
my_list.exs
File metadata and controls
147 lines (108 loc) · 4.04 KB
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
defmodule MyList do
import Enum, only: [at: 2, sort: 1, to_list: 1]
def all_ascii?(chars), do: all?(chars, &(&1 in 32..126))
def anagram?(word1, word2), do: sort(word1) == sort(word2)
def len([]), do: 0
def len([_|xs]), do: 1 + len(xs)
def square([]), do: []
def square([x|xs]), do: [x * x|square(xs)]
def add1([]), do: []
def add1([x|xs]), do: [x + 1|add1(xs)]
def map([], _func), do: []
def map([x|xs], func), do: [func.(x) | map(xs, func)]
# sum with accumulator
# def sum(xs), do: sum(xs, 0)
# defp sum([], total), do: total
# defp sum([x|xs], total), do: sum(xs, total + x)
# without accumulator
def sum([]), do: 0
def sum([x|xs]), do: x + sum(xs)
def reduce([], memo, _func), do: memo
def reduce([x|xs], memo, func), do: reduce(xs, func.(x, memo), func)
def mapsum([], _func), do: 0
def mapsum([x|xs], func), do: func.(x) + mapsum(xs, func)
def max([]), do: nil
def max([x]), do: x
def max([x|xs]), do: larger(x, max(xs))
defp larger(a, b), do: sort([a, b]) |> at(1)
# non-recursive max
# def max(xs), do: reduce(xs, hd(xs), &(&1 > &2 && &1 || &2))
# recursive max with accumulator
# def max([]), do: nil
# def max([x|xs]), do: _max(xs, x)
# defp _max([], result), do: result
# defp _max([x|xs], result), do: _max(xs, larger(x, result))
# defp larger(a, b), do: (if a >= b, do: a, else: b)
def caesar([], _n), do: ''
def caesar([char|chars], n) do
code = char + rem(n, 26)
wrap = if code > ?z, do: 26, else: 0
[code - wrap] ++ caesar(chars, n)
end
# def caesar([char|chars], shift) do
# when char + rem(shift, 26) > ?z,
# do: [char + rem(shift, 26) - 26] ++ caesar(chars, shift)
# end
# def caesar([char|chars], shift) do
# [char + rem(shift, 26)] ++ caesar(chars, shift)
# end
def swapPairs([]), do: []
def swapPairs([a]), do: [a]
def swapPairs([a, b | tail]), do: [b, a | swapPairs(tail)]
# def swap([]), do: []
# def swap([ a, b | tail ]), do: [ b, a | swap(tail) ]
# def swap([_]), do: raise "Can't swap a list with an odd number of elements"
def span(from, to) when from > to, do: []
def span(from, to), do: [from | span(from + 1, to)]
def none?([], _func), do: true
def none?([x|xs], func), do: !func.(x) && none?(xs, func) || false
def is_prime?(n) when n <= 1, do: false
def is_prime?(n), do: none?(span(2, n - 1), &(rem(n, &1) == 0))
def primes_upto(to) when to <= 1, do: []
def primes_upto(to), do: (for n <- span(2, to), is_prime?(n), do: n)
def all?([], _func), do: true
def all?([x|xs], func), do: func.(x) && all?(xs, func) || false
def each([], _func), do: []
def each([x|xs], func), do: [func.(x) | each(xs, func)]
def filter([], _func), do: []
def filter([x|xs], func) do
func.(x) && [x|filter(xs, func)] || filter(xs, func)
end
def split(_, count) when count < 0, do: raise "TODO: Negative count."
def split([], _count), do: [[], []]
def split(xs, 0), do: [[], [xs]]
def split([x|xs], count) do
[a, b] = split(xs, count - 1)
[[x|a], b]
end
def take(_, count) when count < 0, do: raise "TODO: Negative count."
def take([], _count), do: []
def take(_, 0), do: []
def take([x|xs], count), do: [x|take(xs, count - 1)]
def flatten([]), do: []
def flatten([x|xs]) when is_list(x), do: flatten(x) ++ flatten(xs)
def flatten([x|xs]), do: [x|flatten(xs)]
# # -- José Valim version -----------------------
# def flatten(list), do: do_flatten(list, [])
# def do_flatten([h|t], tail) when is_list(h) do
# do_flatten(h, do_flatten(t, tail))
# end
# def do_flatten([h|t], tail) do
# [h|do_flatten(t, tail)]
# end
# def do_flatten([], tail) do
# tail
# end
# ---------------------------------------------
# def split(xs, count), do: split(xs, count, [[], []])
# def split(_, 0, pairs), do: pairs
# def split([x|xs], count, pairs = [a, b]) do
# IO.inspect pairs
# split(xs, count - 1, [[x|a], b])
# end
# def split([], _count, pairs) do
# pairs
# end
end
# [1,2,3], 0, &(&2 + (&1 + 1)) = 2 + 3 + 4 = 9
# MyList.reduce [1,2,3], 0, &(&2 + (&1 + 1))