根據子數組的第一個元素對數組進行排序是一個挑戰。不要直接操作數組,而是考慮另一種方法。
建立引用原始數組的索引數組。依照索引處子數組的第一個元素對索引進行排序。
此策略有幾個優點:
這是一個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中文網其他相關文章!