F # - Ensembles
Un ensemble en F # est une structure de données qui agit comme une collection d'éléments sans préserver l'ordre dans lequel les éléments sont insérés. Les ensembles ne permettent pas d'insérer des entrées en double dans la collection.
Créer des ensembles
Les ensembles peuvent être créés des manières suivantes -
- En créant un ensemble vide à l'aide de Set.empty et en ajoutant des éléments à l'aide de la fonction add.
- Conversion de séquences et de listes en ensembles.
Le programme suivant montre les techniques -
(* creating sets *)
let set1 = Set.empty.Add(3).Add(5).Add(7). Add(9)
printfn"The new set: %A" set1
let weekdays = Set.ofList ["mon"; "tues"; "wed"; "thurs"; "fri"]
printfn "The list set: %A" weekdays
let set2 = Set.ofSeq [ 1 .. 2.. 10 ]
printfn "The sequence set: %A" set2
Lorsque vous compilez et exécutez le programme, il produit la sortie suivante -
The new set: set [3; 5; 7; 9]
The list set: set ["fri"; "mon"; "thurs"; "tues"; "wed"]
The sequence set: set [1; 3; 5; 7; 9]
Opérations de base sur les ensembles
Le tableau suivant présente les opérations de base sur les postes -
Valeur | La description |
---|---|
ajouter: 'T → Set <' T> → Set <'T> | Renvoie un nouvel ensemble avec un élément ajouté à l'ensemble. Aucune exception n'est déclenchée si l'ensemble contient déjà l'élément donné. |
contient: 'T → Set <' T> → booléen | Évalue à true si l'élément donné est dans l'ensemble donné. |
count: Set <'T> → int | Renvoie le nombre d'éléments de l'ensemble. |
différence: Set <'T> → Set <' T> → Set <'T> | Renvoie un nouvel ensemble avec les éléments du second ensemble supprimés du premier. |
vide: définir <'T> | L'ensemble vide pour le type spécifié. |
existe: ('T → bool) → Set <' T> → bool | Teste si un élément de la collection satisfait le prédicat donné. Si la fonction d'entrée est prédicat et que les éléments sont i0 ... iN, cette fonction calcule le prédicat i0 ou ... ou le prédicat iN. |
filtre: ('T → bool) → Set <' T> → Set <'T> | Renvoie une nouvelle collection contenant uniquement les éléments de la collection pour lesquels le prédicat donné retourne true. |
fold: ('State →' T → 'State) →' State → Set <'T> →' State | Applique la fonction d'accumulation donnée à tous les éléments de l'ensemble. |
foldBack: ('T →' State → 'State) → Set <' T> → 'State →' State | Applique la fonction d'accumulation donnée à tous les éléments de l'ensemble. |
forall: ('T → bool) → Set <' T> → bool | Teste si tous les éléments de la collection satisfont au prédicat donné. Si la fonction d'entrée est p et les éléments sont i0 ... iN, alors cette fonction calcule p i0 && ... && p iN. |
intersecter: Set <'T> → Set <' T> → Set <'T> | Calcule l'intersection des deux ensembles. |
intersectMany: seq <Set <'T >> → Set <' T> | Calcule l'intersection d'une séquence d'ensembles. La séquence doit être non vide. |
isEmpty: Set <'T> → booléen | Retour true si l'ensemble est vide. |
isProperSubset: Set <'T> → Set <' T> → booléen | Évalue à true si tous les éléments du premier ensemble sont dans le second et qu'au moins un élément du second n'est pas dans le premier. |
isProperSuperset: Set <'T> → Set <' T> → booléen | Évalue à true si tous les éléments du deuxième ensemble sont dans le premier et qu'au moins un élément du premier n'est pas dans le second. |
isSubset: Set <'T> → Set <' T> → booléen | Évalue à true si tous les éléments du premier ensemble sont dans le second. |
isSuperset: Set <'T> → Set <' T> → booléen | Évalue à true si tous les éléments du deuxième ensemble sont dans le premier. |
iter: ('T → unité) → Set <' T> → unité | Applique la fonction donnée à chaque élément de l'ensemble, dans l'ordre selon la fonction de comparaison. |
map: ('T →' U) → Set <'T> → Set <' U> | Renvoie une nouvelle collection contenant les résultats de l'application de la fonction donnée à chaque élément de l'ensemble d'entrée. |
maxElement: Définir <'T> →' T | Renvoie l'élément le plus élevé de l'ensemble en fonction de l'ordre utilisé pour l'ensemble. |
minElement: Définissez <'T> →' T | Renvoie l'élément le plus bas de l'ensemble en fonction de l'ordre utilisé pour l'ensemble. |
ofArray: 'T tableau → Définir <' T> | Crée un ensemble contenant les mêmes éléments que le tableau donné. |
ofList: 'T liste → Définir <' T> | Crée un ensemble contenant les mêmes éléments que la liste donnée. |
ofSeq: seq <'T> → Set <' T> | Crée une nouvelle collection à partir de l'objet énumérable donné. |
partition: ('T → booléen) → Set <' T> → Set <'T> * Set <' T> | Divise l'ensemble en deux ensembles contenant les éléments pour lesquels le prédicat donné renvoie respectivement true et false. |
supprimer: 'T → Set <' T> → Set <'T> | Renvoie un nouvel ensemble avec l'élément donné supprimé. Aucune exception n'est déclenchée si l'ensemble ne contient pas l'élément donné. |
singleton: 'T → Set <' T> | L'ensemble contenant l'élément donné. |
toArray: Set <'T> →' T tableau | Crée un tableau qui contient les éléments de l'ensemble dans l'ordre. |
toList: Set <'T> →' T liste | Crée une liste qui contient les éléments de l'ensemble dans l'ordre. |
toSeq: Set <'T> → seq <' T> | Renvoie une vue ordonnée de la collection en tant qu'objet énumérable. |
union: Set <'T> → Set <' T> → Set <'T> | Calcule l'union des deux ensembles. |
unionMany: seq <Set <'T >> → Set <' T> | Calcule l'union d'une séquence d'ensembles. |
L'exemple suivant montre les utilisations de certaines des fonctionnalités ci-dessus -
Exemple
let a = Set.ofSeq [ 1 ..2.. 20 ]
let b = Set.ofSeq [ 1 ..3 .. 20 ]
let c = Set.intersect a b
let d = Set.union a b
let e = Set.difference a b
printfn "Set a: "
Set.iter (fun x -> printf "%O " x) a
printfn""
printfn "Set b: "
Set.iter (fun x -> printf "%O " x) b
printfn""
printfn "Set c = set intersect of a and b : "
Set.iter (fun x -> printf "%O " x) c
printfn""
printfn "Set d = set union of a and b : "
Set.iter (fun x -> printf "%O " x) d
printfn""
printfn "Set e = set difference of a and b : "
Set.iter (fun x -> printf "%O " x) e
printfn""
Lorsque vous compilez et exécutez le programme, il produit la sortie suivante -
Set a:
1 3 5 7 9 11 13 15 17 19
Set b:
1 4 7 10 13 16 19
Set c = set intersect of a and b :
1 7 13 19
Set d = set union of a and b :
1 3 4 5 7 9 10 11 13 15 16 17 19
Set e = set difference of a and b :
3 5 9 11 15 17