首頁 >後端開發 >C++ >如何根據子數組的第一個元素對子數組數組進行有效排序?

如何根據子數組的第一個元素對子數組數組進行有效排序?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-11-14 21:55:02403瀏覽

How Can I Sort an Array of Subarrays Based on Their First Element Efficiently?

根據子數組的第一個元素對數組進行排序是一個挑戰。不要直接操作數組,而是考慮另一種方法。

建立引用原始數組的索引數組。依照索引處子數組的第一個元素對索引進行排序。

此策略有幾個優點:

  1. 它比對原始陣列本身進行排序更有效。
  2. 它保留了陣列的原始順序。
  3. 它簡化了複雜排序的處理

這是一個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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn