-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathejsClase08.hs
67 lines (39 loc) · 1.84 KB
/
ejsClase08.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
49
50
51
52
53
54
55
56
type Set a = [a]
vacio :: Set Int
vacio = []
agregar :: (Eq a) => a -> Set a -> Set a
agregar a bs | not (elem a bs) = a:bs
| otherwise = bs
incluido :: (Eq a) => Set a -> Set a -> Bool
incluido [] _ = True
incluido (a:as) (b:bs) | elem a (b:bs) = incluido as (b:bs)
| otherwise = False
agregarATodos :: Int -> Set (Set Int) -> Set (Set Int)
agregarATodos a [] = []
agregarATodos a (b:bs) = (a:b):(agregarATodos a bs)
agregarTodosATodos :: Set Int -> Set (Set Int) -> Set (Set Int)
agregarTodosATodos [] _ = []
agregarTodosATodos (a:as) (b:bs) = agregarATodos a (b:bs) ++ agregarTodosATodos as (b:bs)
-- -----------------------------------------------------------------------
combinatorio :: Int -> Int -> Int
combinatorio n m | m > n = 0
| m == n || m == 0 = 1
| otherwise = combinatorio (n-1) m + combinatorio (n-1) (m-1)
variaciones :: Set Int -> Int -> Set [Int]
variaciones _ 0 = [[]]
variaciones [] _ = []
variaciones (a:as) l = agregarTodosATodos (a:as) (variaciones (a:as) (l-1))
insertarEn :: [a] -> a -> Int -> [a]
insertarEn [] e i = [e]
insertarEn (x:xs) e i | i == 1 = e : x : xs
| otherwise = x : insertarEn xs e (i - 1)
permutaciones :: Int -> Set [Int]
permutaciones 0 = [[]]
permutaciones n = insertarATodosEnTodosLados n (permutaciones (n-1))
insertarATodosEnTodosLados :: Int -> Set [Int] -> Set [Int]
insertarATodosEnTodosLados _ [] = []
insertarATodosEnTodosLados n ([]:pss) = [n]:(insertarATodosEnTodosLados n pss)
insertarATodosEnTodosLados n (ps:pss) = (insertarEnTodosLados n ps n) ++ (insertarATodosEnTodosLados n pss)
insertarEnTodosLados :: Int -> [Int] -> Int -> Set [Int]
insertarEnTodosLados n ps i | i == 0 = []
| otherwise = (insertarEn ps n i) : (insertarEnTodosLados n ps (i - 1))