diff options
author | Determinant <ted.sybil@gmail.com> | 2017-05-29 01:11:20 -0400 |
---|---|---|
committer | Determinant <ted.sybil@gmail.com> | 2017-05-29 01:11:20 -0400 |
commit | fa1bf6c2eac1c9f7969ff29504c9f51b9ba48008 (patch) | |
tree | 3ff5689d025100431adac277d0411ca88681166e /21-28/27.hs | |
parent | 9c608c32a9387a1dd1cb045e5822733ad181ccf8 (diff) |
finish vol 3
Diffstat (limited to '21-28/27.hs')
-rw-r--r-- | 21-28/27.hs | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/21-28/27.hs b/21-28/27.hs new file mode 100644 index 0000000..434f66e --- /dev/null +++ b/21-28/27.hs @@ -0,0 +1,11 @@ +combinations :: Int -> [a] -> [([a], [a])] + +combinations 0 xs = [([], xs)] +combinations _ [] = [] +combinations k (x:xs) = [(x:t1, t2) | (t1, t2) <- combinations (k - 1) xs] ++ + [(t1, x:t2) | (t1, t2) <- combinations k xs] + +group :: [Int] -> [a] -> [[[a]]] + +group _ [] = [[]] +group (n:ns) l = [a:r | (a, b) <- combinations n l, r <- group ns b] |