> 백엔드 개발 > Golang > Go에서 2D 배열을 어떻게 효율적으로 정렬할 수 있나요?

Go에서 2D 배열을 어떻게 효율적으로 정렬할 수 있나요?

Patricia Arquette
풀어 주다: 2024-12-23 09:52:08
원래의
587명이 탐색했습니다.

How Can I Efficiently Sort a 2D Array in Go?

Go에서 2차원 배열 정렬

행렬이라고도 하는 2차원 배열은 다양한 프로그래밍 애플리케이션에서 자주 사용됩니다. Go에서 2차원 배열을 사용하여 작업하고 이를 정렬해야 하는 경우 표준 라이브러리는 이 작업을 위해 특별히 내장된 메서드를 제공하지 않습니다. 그러나 사용할 수 있는 몇 가지 전략이 있습니다.

사용자 정의 정렬 방법 만들기:

한 가지 접근 방식은 자신만의 정렬 방법을 정의하는 것입니다. 이는 sort.Interface 인터페이스에 필요한 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] }
로그인 후 복사

sort.Slice 함수 사용:

또는 sort.Slice 함수를 사용할 수 있습니다. , 정렬에 더 많은 유연성을 제공합니다. 2D 배열을 슬라이스로 변환하고 사용자 지정 less 함수를 지정합니다.

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
})
로그인 후 복사

이러한 전략 중 하나를 구현하고 적절한 정렬 기능을 제공하면 Go에서 2차원 배열을 효과적으로 정렬할 수 있습니다. 구체적인 사용 방법은 특정 요구 사항과 선호도에 따라 다릅니다.

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

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