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