"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Go에서 여러 기준에 따라 중첩된 슬라이스가 있는 구조체 슬라이스를 어떻게 정렬합니까?

Go에서 여러 기준에 따라 중첩된 슬라이스가 있는 구조체 슬라이스를 어떻게 정렬합니까?

2024-11-08에 게시됨
검색:180

How do you sort a slice of structs with nested slices in Go based on multiple criteria?

중첩 슬라이스로 구조체 슬라이스 정렬

Go에서는 내장된 정렬 패키지를 사용하여 사용자 정의 구조체 슬라이스를 정렬할 수 있습니다. 부모-자식 관계를 나타내는 두 개의 구조체 Parent 및 Child를 정의하는 다음 코드를 고려하십시오.

type Parent struct {
    id       string
    children []Child
}

type Child struct {
    id string
}

부모 구조체 조각이 있고 두 가지 기준에 따라 정렬하려고 한다고 가정합니다.

정렬 기준:

  1. 정렬 Parent.id를 기준으로 Parent 슬라이스를 오름차순으로 정렬합니다.
  2. 각 Parent에 대해 Child.id를 기준으로 하위 슬라이스를 오름차순으로 정렬합니다. 상위 내에서.

해결책:

제공된 코드 조각은 정렬 요구 사항을 해결합니다.

``
// sort Id
sort.Slice(parents, func(i, j int) bool로 부모 슬라이스의 각 부모 {

return parents[i].id 

// 각 부모에 대해 자식 슬라이스의 각 자식을 Id로 정렬
for _, parent := range parent {

sort.Slice(parent.children, func(i, j int) bool { 
    return parent.children[i].id 

}
``

sort.Slice 함수는 슬라이스에서 직접 작동하여 다음을 제거합니다. 중간 컨테이너가 필요합니다.

  1. Parent.id를 기준으로 상위 슬라이스를 정렬합니다.
  2. 정렬된 상위 슬라이스의 각 상위에 대해 중첩 루프를 사용하여 Child.id를 기반으로 하위 슬라이스를 정렬합니다.

결과는 예상 출력과 일치합니다.

[{1 [{7} {8} {9}]} {2 [{4} {5} {6}]} {3 [{1} {2} {3}]}]
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3