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 중국어 웹사이트의 기타 관련 기사를 참조하세요!