하위 배열의 첫 번째 요소를 기준으로 배열을 정렬하는 것은 어려운 일입니다. 배열을 직접 조작하는 대신 대체 접근 방식을 고려해 보세요.
원본 배열을 참조하는 인덱스 배열을 만듭니다. 해당 인덱스에 있는 하위 배열의 첫 번째 요소를 기준으로 인덱스를 정렬합니다.
이 전략에는 여러 가지 장점이 있습니다.
다음은 C의 예입니다.
#include <algorithm> #include <iostream> int main() { int index[3] = {0, 1, 2}; int timeTable[3][2] = {{4, 204}, {10, 39}, {1, 500}}; std::sort(index, index + 3, [&timeTable](int n1, int n2) { return timeTable[n1][0] < timeTable[n2][0]; }); for (int i = 0; i < 3; ++i) { std::cout << "The index is " << index[i] << ". The data at this index is [" << timeTable[index[i]][0] << " " << timeTable[index[i]][1] << "]\n"; } return 0; }
실시간 예
원래 배열을 조작하는 대신 인덱스를 사용하면 복잡한 데이터 구조를 정렬할 수 있습니다. 더욱 효율적이고 편리하게.
위 내용은 첫 번째 요소를 기반으로 하위 배열 배열을 효율적으로 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!