Heim >Backend-Entwicklung >Golang >Wie sortiere ich komplexe Datenstrukturen mit mehreren Ebenen untergeordneter Slices?
Sortieren komplexer Datenstrukturen mit mehreren Ebenen untergeordneter Slices
In diesem Artikel wird eine Methode zum Organisieren komplexer Datenstrukturen mit Slices und Sub-Slices untersucht durch die Berücksichtigung mehrerer Sortieranforderungen. Stellen Sie sich das folgende Szenario vor:
Eingabedatenstruktur:
Ein Teil der übergeordneten Strukturen:
type Parent struct { id string children []Child }
Jedes übergeordnete Element hat ein Segment untergeordneter Strukturen:
type Child struct { id string }
Sortierziele:
Gewünschte Ausgabe:
[{1 [{7} {8} {9}]} {2 [{4} {5} {6}]} {3 [{1} {2} {3}]}]
Implementierung:
Um diese Sortierziele zu erreichen, werden die folgenden Schritte unternommen:
Sortieren des übergeordneten Slice:
sort.Slice(parents, func(i, j int) bool {return parents[i].id < parents[j].id})
Diese Zeile sortiert die übergeordneten Slices in aufsteigender Reihenfolge ihres ID-Felds mithilfe der integrierten Funktion „sort.Slice“.
Untergeordnete Slices sortieren :
for _, parent := range parents { sort.Slice(parent.children, func(i, j int) bool {return parent.children[i].id < parent.children[j].id}) }
Diese Schleife durchläuft jedes übergeordnete Element im sortierten Parent-Slice und verwendet eine weitere Instanz von sort.Slice, um das untergeordnete Segment jedes übergeordneten Elements in aufsteigender Reihenfolge ihres ID-Felds zu sortieren.
Durch Befolgen dieser Schritte kann die komplexe Datenstruktur effektiv sortiert werden, um die angegebenen Sortieranforderungen zu erfüllen, was zum gewünschten Ausgabeformat führt.
Das obige ist der detaillierte Inhalt vonWie sortiere ich komplexe Datenstrukturen mit mehreren Ebenen untergeordneter Slices?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!