-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmoreList.hs
32 lines (23 loc) · 1.44 KB
/
moreList.hs
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
-- concat flattens a list of lists into just a list of elements.
concat' :: Foldable t => t [a] -> [a]
concat' = foldr (\acc x -> acc++x) []
-- Doing concatMap is the same as first mapping a function to a list and then concatenating the list with concat
concatMap' :: (t -> [a]) -> [t] -> [a]
concatMap' fn = concat . map (\elem -> fn elem)
-- and takes a list of boolean values and returns True only if all the values in the list are True.
and' :: [Bool] -> Bool
and' = foldl (\x acc -> if x then acc else False) True
-- or is like and, only it returns True if any of the boolean values in a list is True.
or' :: [Bool] -> Bool
or' = foldl (\x acc -> if x then True else acc) False
any' :: (t -> Bool) -> [t] -> Bool
any' fn list = or $ map(\el -> fn el) list
all' :: (t -> Bool) -> [t] -> Bool
all' fn = and . map(\el -> fn el)
-- iterate takes a function and a starting value. It applies the function to the starting value, then it applies that function to the result, then it applies the function to that result again, etc. It returns all the results in the form of an infinite list.
-- take 10 $ iterate (*2) 1 -> [1,2,4,8,16,32,64,128,256,512]
-- take 3 $ iterate (++ "haha") "haha" -> ["haha","hahahaha","hahahahahaha"]
iterate' :: (a -> a) -> a -> [a]
iterate' fn start = iterate'' [start] start
where iterate'' list acc = list ++ let fnVal = fn acc
in iterate'' [fnVal] (fnVal)