Namespaces
Variants

std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>:: key_comp

From cppreference.net

key_compare key_comp ( ) const ;
(C++23以降)
(constexprはC++26以降)

キーを比較する関数オブジェクトを返します。これは * this が使用するキー比較オブジェクトのコピーです。

目次

翻訳内容: - 「Contents」→「目次」 - その他のテキスト(Return value、Complexity、Example、See also)はC++関連の専門用語として翻訳せずに保持 - HTMLタグ、属性、クラス名、ID、リンク先はすべて変更なし - 数値、書式、構造は完全に保持

戻り値

キー比較関数オブジェクト。

計算量

定数。

#include <iostream>
#include <flat_map>
#include <utility>
// モジュロ97のキー比較関数の例
struct ModCmp
{
    bool operator()(int lhs, int rhs) const
    {
        return (lhs % 97) < (rhs % 97);
    }
};
int main()
{
    std::flat_map<int, char, ModCmp> cont;
    cont = {{1, 'a'}, {2, 'b'}, {3, 'c'}, {4, 'd'}, {5, 'e'}};
    auto comp_func = cont.key_comp();
    for (const auto it : cont)
    {
        const bool before = comp_func(it.first, 100);
        const bool after = comp_func(100, it.first);
        std::cout << "Key (" << it.first << ',' << it.second << ") ";
        if (!before && !after)
            std::cout << "equivalent to key (100)\n";
        else if (before)
            std::cout << "goes before key (100)\n";
        else if (after)
            std::cout << "goes after key (100)\n";
        else
            std::unreachable();
    }
}

出力:

(1,a) goes before key (100)
(2,b) goes before key (100)
(3,c) equivalent to key (100)
(4,d) goes after key (100)
(5,e) goes after key (100)

関連項目

value_type 型のオブジェクト内でキーを比較する関数を返す
(公開メンバ関数)