根据子数组的第一个元素对数组进行排序是一个挑战。不要直接操作数组,而是考虑另一种方法。
创建引用原始数组的索引数组。根据索引处子数组的第一个元素对索引进行排序。
此策略有几个优点:
这是一个 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; }
Live示例
通过使用索引而不是操作原始数组,可以更高效、更方便地对复杂数据结构进行排序。
以上是如何根据子数组的第一个元素对子数组数组进行有效排序?的详细内容。更多信息请关注PHP中文网其他相关文章!