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