다음 상위 및 하위 구조체를 고려하세요.
type Parent struct { id string children []Child } type Child struct { id string }
미리 정의된 값을 가진 상위 구조체 조각이 있다고 가정합니다.
parents := []Parent{ { "3", []Child{ {"2"}, {"3"}, {"1"}, }, }, { "1", []Child{ {"8"}, {"9"}, {"7"}, }, }, { "2", []Child{ {"5"}, {"6"}, {"4"}, }, }, }
정렬 요구 사항:
우리의 목표는 두 가지 기준에 따라 상위 슬라이스를 정렬하는 것입니다:
해결책:
이 정렬을 수행하기 위해 사용자 정의 비교 함수를 기반으로 슬라이스를 정렬하는 유연한 방법을 제공하는 sort.Slice 함수를 사용합니다. 코드는 다음과 같습니다.
// Sort parents by their ID
sort.Slice(parents, func(i, j int) bool { return parents[i].id 이 정렬 알고리즘은 두 기준을 모두 효율적으로 처리하여 상위 슬라이스가 원하는 대로 정렬되도록 합니다.
예상 결과:
정렬된 슬라이스는 다음과 같아야 합니다. 다음 구조와 유사합니다.
[{1 [{7} {8} {9}]} {2 [{4} {5} {6}]} {3 [{1} {2} {3}]}]
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3