Maison >développement back-end >Golang >Comment trier des structures de données complexes avec plusieurs niveaux de tranches enfants ?
Tri des structures de données complexes avec plusieurs niveaux de tranches enfants
Cet article explore une méthode d'organisation de structures de données complexes impliquant des tranches et des sous-tranches en respectant plusieurs exigences de tri. Considérez le scénario suivant :
Structure de données d'entrée :
Une tranche de structures parent :
type Parent struct { id string children []Child }
Chaque parent a une tranche de structures enfants :
type Child struct { id string }
Objectifs de tri :
Sortie souhaitée :
[{1 [{7} {8} {9}]} {2 [{4} {5} {6}]} {3 [{1} {2} {3}]}]
Mise en œuvre :
Pour atteindre ces objectifs de tri, les étapes suivantes sont suivies :
Trier la tranche parent :
sort.Slice(parents, func(i, j int) bool {return parents[i].id < parents[j].id})
Cette ligne trie les tranches des parents par ordre croissant de leur champ d'identification à l'aide de la fonction sort.Slice intégrée.
Trier les tranches enfants :
for _, parent := range parents { sort.Slice(parent.children, func(i, j int) bool {return parent.children[i].id < parent.children[j].id}) }
Cette boucle parcourt chaque parent dans la tranche des parents triés et utilise une autre instance de sort.Slice pour trier la tranche des enfants de chaque parent par ordre croissant de leur champ d'identification.
En suivant ces étapes, la structure de données complexe peut être triée efficacement pour satisfaire aux exigences de tri spécifiées, ce qui donne le format de sortie souhaité.
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!