Application d'éléments uniques dans des structures de données de type tableau
Dans le domaine de la programmation, la tâche de créer un tableau avec des chaînes uniques se pose souvent . Cependant, la question de savoir comment garantir l’unicité au sein d’un tableau peut laisser les développeurs perplexes. Passons aux solutions.
Utilisation du type de données défini
Bien que Go n'offre pas de type de données défini intégré, l'utilisation d'une carte peut servir de alternative intelligente. Les cartes offrent une propriété unique selon laquelle les clés doivent être distinctes. Cette contrainte nous permet d'exploiter les cartes pour émuler le comportement défini.
Pour une implémentation soignée, une carte avec des valeurs booléennes constitue une solution élégante. La valeur zéro de bool, qui est fausse, correspond commodément à l'absence d'un élément dans l'ensemble.
Exploiter les valeurs zéro
La version "sympa" de ce L'implémentation de l'ensemble implique l'ajout d'éléments comme clés de la carte avec de vraies valeurs. Pour déterminer la présence d'un élément, utilisez simplement une expression d'index :
exists := m["somevalue"]
Cette approche exploite la valeur zéro, renvoyant false si l'élément n'est pas trouvé, et true sinon.
Maintenir l'ordre avec des tranches
Dans les cas où l'ordre est crucial, une combinaison d'une tranche et d'une carte peut être utilisée. La tranche maintient l'ordre, tandis que la carte garantit l'unicité. Voici une fonction d'assistance qui accomplit cela :
var m = make(map[string]bool) var a = []string{} func add(s string) { if m[s] { return } a = append(a, s) m[s] = true }
Cette fonction garantit qu'aucun élément en double n'est ajouté à la fois à la tranche et à la carte, en conservant à la fois l'unicité et l'ordre.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!