-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpractice.hs
48 lines (35 loc) · 1.77 KB
/
practice.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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
--http://www.haskell.org/haskellwiki/Tutorials/Programming_Haskell/Argument_handling
import Data.List.Split
--anything does what dr dre does only better
splitList :: Int -> Int -> [[Int]]
splitList b a
| a == 0 = []
| otherwise = chunksOf a [1..b]
--eminem takes a list of lists and divided the elements into sublists of even/odd
eminem :: (Integral a) => [[a]] -> [[a]]
eminem xxs = [ [ x | x <- xs, even x ] | xs <- xxs] ++ [ [ y | y <- ys, odd y ] | ys <- xxs]
--Checks if the total number of students can be split into said group size
checkmod x y = (if mod x y == 0 then putStrLn "Yay" else putStrLn $"Cannot pair up " ++ (show x) ++ " students into groups of " ++ show(y) ++ "across eight assignments")
--Takes list of total students [1..howevermany]
--Out puts a list of tuples first element being the student ID number
--Second being a list
--for storing the students already been grouped with
studentstruct ss = [(x,[x]) | x <- ss]
--right now adds student to everyone
--will be called to add to specific tuple's list
addstudent ss s = [(a,s:[b])|(a,[b]) <- ss]
--checkstudentused ss i = map elem i (map snd ss)
chch ss = map snd ss
-- | ss == 1 "YAY"
-- | length $ map snd ss > 1 = "something else"
-- | otherwise = "WHAT!?"
-- Will be used for each student if student "i" is in list
-- try another student else use add each student to each other's list
checkindivdual i t= if elem i $ snd t
then putStrLn "yay"
else putStrLn "boo"
--this takes lists and pairs their elements by order
createList :: (Integral a) => [a] -> [a] -> [a] -> [[a]]
createList a b c
| length a == 1 || length b == 1 || length c == 1 = ((head a) : (head b) : (head c) : []):[]
| otherwise = ((head a) : (head b) : (head c) : []):[] ++ createList (tail a) (tail b) (tail c)