Trouver la distinction entre deux tranches de chaîne
Lorsqu'il s'agit de tranches de chaîne en programmation, il est souvent nécessaire de déterminer les différences entre deux ensembles. Considérons le scénario suivant :
slice1 := []string{"foo", "bar","hello"} slice2 := []string{"foo", "bar"}
Notre objectif est d'identifier et de générer les éléments qui existent dans la tranche 1 mais pas dans la tranche2.
Utiliser une HashMap pour une recherche efficace
Pour calculer efficacement la différence, nous pouvons exploiter une carte Go. Maps in Go propose une recherche en temps constant (O(1)), ce qui nous permet de déterminer rapidement si un élément existe dans un ensemble.
Implémentation de la fonction de différence
Voici une implémentation de la fonction de différence à l'aide d'une carte :
// difference returns the elements in `a` that aren't in `b`. func difference(a, b []string) []string { mb := make(map[string]struct{}, len(b)) for _, x := range b { mb[x] = struct{}{} } var diff []string for _, x := range a { if _, found := mb[x]; !found { diff = append(diff, x) } } return diff }
Décomposer les Fonction
Cette implémentation a une complexité temporelle approximative de O(n), où n est la longueur maximale de slice1 et slice2. Son efficacité provient des opérations à temps constant effectuées par la carte, qui garantissent une recherche et une insertion rapides.
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!