「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > ペアのベクトルを2番目の要素で効率的に並べ替える方法は?

ペアのベクトルを2番目の要素で効率的に並べ替える方法は?

2025-02-26に投稿されました
ブラウズ:198

How to Efficiently Sort a Vector of Pairs by the Second Element?

ペアの2番目の要素でペアのベクトルを効率的に並べ替える方法

この記事では、この記事は、ペアのベクトルをソートするという質問に対処します。昇順で各ペアの2番目の要素。このタスクのカスタム関数オブジェクトを作成することは実行可能なソリューションですが、既存のSTLコンポーネントとstd :: lessを使用する代替方法があります。

1つのアプローチは、STD :: sortのオプションの3番目の引数としてカスタムコンパレータを採用することです。 sort_predと呼ばれるこのカスタムコンパレーターは、次のように定義されています。 bool operator()(const std :: pair& left、const std :: pair& right){ left.second このコンパレータを利用するには、単にstd :: sortに渡すだけです:

std :: sort(v.begin()、v.end()、sort_pred());

struct sort_pred {
    bool operator()(const std::pair<int,int> &left, const std::pair<int,int> &right) {
        return left.second < right.second;
    }
};
c 11 lambdas

std::sort(v.begin(), v.end(), sort_pred());

std :: sort(v.begin()、v.end()、[](const std :: pair& left、const std :: pair右){ left.second

ペアソートに汎用テンプレートを使用して

std::sort(v.begin(), v.end(), [](const std::pair<int,int> &left, const std::pair<int,int> &right) {
    return left.second < right.second;
});

テンプレートと呼ばれる一般的なテンプレートを作成できます。 > struct sort_pair_second { bool operator()(const std :: pair& left、const std :: pair& right){ Pred P; p(left.second、right.second)を返します。 } }; このテンプレートを使用すると、次のように目的のソートを実現できます。 ());

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3