Maison >développement back-end >Golang >Comment puis-je supprimer efficacement les éléments en double des tranches Go ?

Comment puis-je supprimer efficacement les éléments en double des tranches Go ?

Susan Sarandon
Susan Sarandonoriginal
2024-12-16 17:04:14201parcourir

How Can I Efficiently Remove Duplicate Elements from Go Slices?

Optimisation de la suppression des doublons dans Go Slices

Introduction

Les rencontres avec des ensembles de données contenant des éléments en double sont monnaie courante, en particulier dans les scénarios impliquant une collecte de données approfondie. La suppression de ces doublons pour obtenir des valeurs uniques est cruciale pour diverses opérations. En Go, pour y parvenir, il faut des algorithmes efficaces pour minimiser la complexité temporelle et spatiale. Cet article explore une solution complète pour supprimer les doublons des tranches de chaînes ou d'entiers.

Implémentation générique

La première approche exploite les génériques, disponibles dans Go v1.18 et versions ultérieures. , pour gérer des tranches de tout type comparable (T). Il utilise une carte pour suivre les valeurs rencontrées, garantissant que seuls les éléments uniques sont ajoutés à la tranche résultante.

func removeDuplicate[T comparable](sliceList []T) []T {
    allKeys := make(map[T]bool)
    list := []T{}
    for _, item := range sliceList {
        if _, value := allKeys[item]; !value {
            allKeys[item] = true
            list = append(list, item)
        }
    }
    return list
}

Optimisation spécifique aux chaînes

Pour les tranches contenant uniquement chaînes, il existe une solution plus optimisée utilisant la fonction make. Il initialise la carte avec la taille de la tranche d'entrée, éliminant ainsi le besoin de redimensionnement dynamique et les pénalités potentielles de performances.

func removeDuplicateStr(strSlice []string) []string {
    allKeys := make(map[string]bool, len(strSlice))
    list := []string{}
    for _, item := range strSlice {
        if _, value := allKeys[item]; !value {
            allKeys[item] = true
            list = append(list, item)
        }
    }
    return list
}

Optimisation spécifique aux entiers

Similaire à l'approche spécifique aux chaînes, une fonction spécialisée pour les tranches d'entiers peut exploiter la fonction make pour améliorer performances.

func removeDuplicateInt(intSlice []int) []int {
    allKeys := make(map[int]bool, len(intSlice))
    list := []int{}
    for _, item := range intSlice {
        if _, value := allKeys[item]; !value {
            allKeys[item] = true
            list = append(list, item)
        }
    }
    return list
}

Utilisation

Quel que soit le type de tranche, l'utilisation de ces fonctions reste simple. Passez simplement la tranche d'entrée comme argument et vous recevrez une tranche contenant uniquement les éléments uniques.

cities := []string{"Mumbai", "Delhi", "Ahmedabad", "Mumbai", "Bangalore", "Delhi", "Kolkata", "Pune"}
uniqueCities := removeDuplicate(cities)

fmt.Println(uniqueCities) // [Mumbai Delhi Ahmedabad Bangalore Kolkata Pune]

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn