summaryrefslogtreecommitdiff
path: root/21-28/27.hs
diff options
context:
space:
mode:
authorDeterminant <ted.sybil@gmail.com>2017-05-29 01:11:20 -0400
committerDeterminant <ted.sybil@gmail.com>2017-05-29 01:11:20 -0400
commitfa1bf6c2eac1c9f7969ff29504c9f51b9ba48008 (patch)
tree3ff5689d025100431adac277d0411ca88681166e /21-28/27.hs
parent9c608c32a9387a1dd1cb045e5822733ad181ccf8 (diff)
finish vol 3
Diffstat (limited to '21-28/27.hs')
-rw-r--r--21-28/27.hs11
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]