recherche
Maisondéveloppement back-endGolangComment puis-je supprimer efficacement les éléments en double des tranches Go ?

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
Implémentation de mutex et verrouilleImplémentation de mutex et verrouilleMay 05, 2025 am 12:18 AM

En Go, l'utilisation de mutex et de verrous est la clé pour assurer la sécurité des filetages. 1) Utiliser Sync.Mutex pour un accès mutuellement exclusif, 2) Utiliser Sync.rwmutex pour les opérations de lecture et d'écriture, 3) Utilisez des opérations atomiques pour l'optimisation des performances. La maîtrise de ces outils et leurs compétences d'utilisation est essentielle pour rédiger des programmes concurrents efficaces et fiables.

Benchmarking and ProfilBenchmarking and ProfilMay 05, 2025 am 12:18 AM

Comment optimiser les performances du code GO simultané? Utilisez des outils intégrés de Go tels que GetSest, Gobench et PPROF pour l'analyse comparative et l'analyse des performances. 1) Utilisez le package de tests pour écrire des repères pour évaluer la vitesse d'exécution des fonctions simultanées. 2) Utilisez l'outil PPROF pour effectuer une analyse des performances et identifier les goulots d'étranglement du programme. 3) Ajustez les paramètres de collecte des ordures pour réduire son impact sur les performances. 4) Optimiser le fonctionnement du canal et limiter le nombre de goroutins pour améliorer l'efficacité. Grâce à l'analyse comparative continue et à l'analyse des performances, les performances du code GO simultanée peuvent être efficacement améliorées.

Gestion des erreurs dans les programmes GO simultanés: éviter les pièges communsGestion des erreurs dans les programmes GO simultanés: éviter les pièges communsMay 05, 2025 am 12:17 AM

Méthodes pour éviter les pièges courants de la gestion des erreurs dans les programmes GO simultanés comprennent: 1. Assurer la propagation des erreurs, 2. Traitement du traitement, 3. Erreurs d'agrégation, 4. Utiliser la gestion du contexte, 5. Erreur Erchage, 6. Loggation, 7. Test. Ces stratégies aident à gérer efficacement les erreurs dans des environnements simultanés.

Implémentation de l'interface implicite dans Go: la puissance de la saisie du canardImplémentation de l'interface implicite dans Go: la puissance de la saisie du canardMay 05, 2025 am 12:14 AM

ImplicitInterfaceImplementationingoembodiesDuckTypingByLingyPestosuissalifyInterfaceswithoutExplicitDeclaration.1) itpromotesflexibility andmodulatyByfocusingonBehavior.2) ChallengeSinclucdUpDatingMethodsignatUrsAndTrackingImPlementations.3) Toolslili

GO TANCER ERREUR: meilleures pratiques et modèlesGO TANCER ERREUR: meilleures pratiques et modèlesMay 04, 2025 am 12:19 AM

Dans la programmation GO, les moyens de gérer efficacement les erreurs incluent: 1) en utilisant des valeurs d'erreur au lieu d'exceptions, 2) en utilisant des techniques d'emballage des erreurs, 3) la définition des types d'erreur personnalisés, 4) Réutiliser les valeurs d'erreur pour les performances, 5) en utilisant la panique et la récupération avec prudence, 6) assurer que les messages d'erreur sont clairs et cohérents, 7) enregistrer les stratégies d'erreur d'enregistrement, traitant les erreurs de première classe Citizens, 9). Ces pratiques et modèles aident à écrire un code plus robuste, maintenable et efficace.

Comment implémentez-vous la concurrence dans GO?Comment implémentez-vous la concurrence dans GO?May 04, 2025 am 12:13 AM

La mise en œuvre de la concurrence dans GO peut être obtenue en utilisant des goroutines et des canaux. 1) Utilisez des goroutines pour effectuer des tâches en parallèle, comme profiter de la musique et observer des amis en même temps dans l'exemple. 2) Transférer solidement les données entre les goroutines via des canaux, tels que les modèles producteurs et consommateurs. 3) Évitez l'utilisation excessive des goroutines et des impasses et concevez le système raisonnablement pour optimiser les programmes simultanés.

Construire des structures de données simultanées en GoConstruire des structures de données simultanées en GoMay 04, 2025 am 12:09 AM

GooffersMultipleAPPROYSFORBULDINGSCURRENTDATASTASTRUCTURES, notamment desMutexes, des canaux et des données.1)

Comparaison de la gestion des erreurs de Go à d'autres langages de programmationComparaison de la gestion des erreurs de Go à d'autres langages de programmationMay 04, 2025 am 12:09 AM

Go'SerrorHandlinlingexplicit, traitantaRrorsaSreturnedValuesRatherThanExceptions, contrairement

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP