如何创建一个STD::用C++中的自定义比较器设置?
如何创建一组对,这些对的元素使用自定义bool函数进行排序?我写如何创建一个STD::用C++中的自定义比较器设置?,c++,set,comparator,std-pair,C++,Set,Comparator,Std Pair,如何创建一组对,这些对的元素使用自定义bool函数进行排序?我写 set <pair<int,int>,compare> myset; 获取错误:参数2的类型/值不匹配,应为类型,获取比较 我把比较定义为 bool compare(pair <int,int> g1, pair <int,int> g2) { return (g1.second-g1.first > g2.second-g2.first); } 当然 #inclu
set <pair<int,int>,compare> myset;
获取错误:参数2的类型/值不匹配,应为类型,获取比较
我把比较定义为
bool compare(pair <int,int> g1, pair <int,int> g2)
{
return (g1.second-g1.first > g2.second-g2.first);
}
当然
#include <vector>
#include <set>
方法1:使用
编写一个重载运算符的类,以便像调用函数一样调用它:
struct compare {
bool operator() (const pair<int,int> &lhs, const pair<int,int> &rhs) const{
return (lhs.second-lhs.first > rhs.second-rhs.first);
}
};
方法1:使用
编写一个重载运算符的类,以便像调用函数一样调用它:
struct compare {
bool operator() (const pair<int,int> &lhs, const pair<int,int> &rhs) const{
return (lhs.second-lhs.first > rhs.second-rhs.first);
}
};
您应该使用函数对象。这里有一个例子
#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;
}
您应该使用函数对象。这里有一个例子
#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;
}
您还可以使用函数。你只需要得到正确的类型。你也可以使用函数。你只需要把字体弄对就行了。