Go에서 2D 배열을 어떻게 정렬할 수 있나요?

Linda Hamilton
풀어 주다: 2024-11-26 00:30:10
원래의
209명이 탐색했습니다.

How Can I Sort a 2D Array in Go?

Go에서 2차원 배열 정렬

Go에서는 정렬 방법을 수동으로 정의하여 다차원 배열을 정렬할 수 있습니다. 두 가지 접근 방식을 취할 수 있습니다:

1. sort.Sort 인터페이스 구현:

sort.Sort와 함께 사용할 Len, Less 및 Swap에 대한 사용자 정의 메서드를 생성하면 정렬 중에 배열 값을 수정할 수 있습니다. 예:

type Matrix [3][3]int

func (m Matrix) Len() int { return len(m) }
func (m Matrix) Less(i, j int) bool {
    for x := range m[i] {
        if m[i][x] == m[j][x] {
            continue
        }
        return m[i][x] < m[j][x]
    }
    return false
}

func (m *Matrix) Swap(i, j int) { m[i], m[j] = m[j], m[i] }
func main() {
    m := Matrix(matrix)
    sort.Sort(&m)
}
로그인 후 복사

2. sort.Slice 함수 사용:

배열을 슬라이스로 변환하고 sort.Slice에 대해 유사한 함수를 제공하여 정렬을 처리합니다. 예를 들면 다음과 같습니다.

sort.Slice(matrix[:], func(i, j int) bool {
    for x := range matrix[i] {
        if matrix[i][x] == matrix[j][x] {
            continue
        }
        return matrix[i][x] < matrix[j][x]
    }
    return false
})

fmt.Println(matrix)
로그인 후 복사

두 가지 접근 방식을 모두 사용하면 Go에서 2차원 배열의 정렬 동작을 맞춤설정할 수 있습니다.

위 내용은 Go에서 2D 배열을 어떻게 정렬할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿