如何在C++中创建带有自定义比较器的std::set

How to create a std::set with custom comparator in C++?

本文关键字:比较器 自定义 std set C++ 创建      更新时间:2023-10-16

如何创建一组对,其中的元素(对)使用自定义布尔函数进行排序?我写

set <pair<int,int>,compare> myset;

并得到错误:参数2的类型/值不匹配,应为类型,得到"compare"

我已将"比较"定义为

bool compare(pair <int,int> g1, pair <int,int> g2)
{
    return (g1.second-g1.first > g2.second-g2.first);
}

当然还有

#include <vector>
#include <set>

方法1:使用函子

编写一个重载operator()的类,以便可以像函数一样调用它:

struct compare {
    bool operator() (const pair<int,int> &lhs, const pair<int,int> &rhs) const{
         return (lhs.second-lhs.first > rhs.second-rhs.first);
    }
};

然后,您可以使用类名作为类型参数

set<pair<int,int>, compare> myset;

方法2:使用函数指针

假设compare是您想要使用的函数:

set<pair<int,int>, bool(*)(const pair<int,int> &lhs, 
                           const pair<int,int> &rhs)
   > myset(&compare);

您应该使用一个函数对象。以下是的示例

#include <iostream>
#include <set>
#include <utility>
struct Compare
{
    bool operator ()( const std::pair<int, int> &p1, 
                      const std::pair<int, int> &p2 ) const
    {
        return ( p1.second - p1.first  > p2.second - p2.first );
    }
};
int main() 
{
    std::set<std::pair<int, int>, Compare> s;
    return 0;
}