Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/container/set/value comp"

From cppreference.com
< cpp‎ | container‎ | set
m (r2.7.3) (Robot: Adding de, fr, it, ja, pt, zh)
m (Shorten template names. Use {{lc}} where appropriate.)
Line 1: Line 1:
{{page template|cpp/container/value_comp|set}}
+
{{include page|cpp/container/value_comp|set}}
  
 
[[de:cpp/container/set/value comp]]
 
[[de:cpp/container/set/value comp]]

Revision as of 19:35, 31 May 2013

 
 
 
 
std::set::value_compare value_comp() const;

Returns the function object that compares the values. It is the same as key_comp.

Contents

Parameters

(none)

Return value

The value comparison function object.

Complexity

Constant.

Example

#include <iostream>
#include <set>
#include <utility>
 
// Example module 97 key compare function
struct ModCmp
{
    bool operator()(int lhs, int rhs) const
    {
        return (lhs % 97) < (rhs % 97);
    }
};
 
int main()
{
    std::set<int, ModCmp> cont{1, 2, 3, 4, 5};
 
    // Same behaviour as key_comp()
    auto comp_func = cont.value_comp();
 
    for (const int val{100}; const int key : cont)
    {
        const bool before = comp_func(key, val);
        const bool after = comp_func(val, key);
 
        std::cout << "Key (" << key << ") ";
        if (!before && !after)
            std::cout << "equivalent to key (" << val << ")\n";
        else if (before)
            std::cout << "goes before key (" << val << ")\n";
        else if (after)
            std::cout << "goes after key (" << val << ")\n";
        else
            std::unreachable();
    }
}

Output:

Key (1) goes before key (100)
Key (2) goes before key (100)
Key (3) equivalent to key (100)
Key (4) goes after key (100)
Key (5) goes after key (100)

See also

returns the function that compares keys
(public member function) [edit]