alea/Alea/List.hs

17 lines
457 B
Haskell
Raw Normal View History

2014-10-14 18:09:58 +02:00
module Alea.List where
2014-10-13 21:26:55 +02:00
-- Remove the nth element of a list. (0-indexed)
-- RemoveAt 2 "abc" == ('c', "ab")
removeAt :: Int -> [a] -> (a, [a])
removeAt n xs = (xs !! n, take n xs ++ drop (n+1) xs)
2014-10-14 18:09:58 +02:00
-- Split a list into a list of lists
2014-10-16 23:00:52 +02:00
-- ex. split ',' "ab,cd,ef" == ["ab","cd","ef"]
split :: (Eq a) => a -> [a] -> [[a]]
split _ [] = [[]]
split delim (c:cs)
2014-10-14 18:09:58 +02:00
| c == delim = [] : rest
2014-10-13 21:26:55 +02:00
| otherwise = (c : head rest) : tail rest
where
2014-10-16 23:00:52 +02:00
rest = split delim cs