比较器comp
定义如下。它工作正常,std::sort
,但未能在std::priority_queue
的构造函数中编译。问题是什么?谢谢。为什么这个自定义比较器在为std :: sort工作时,在构建std :: priority_queue失败?
#include <vector>
#include <queue>
#include <algorithm>
using namespace std;
bool comp(int a, int b) { return a > b; }
int main()
{
vector<int> vec = {4, 2, 1, 3};
sort(vec.begin(), vec.end(), comp); // OK
priority_queue<int> q1(less<int>(), vec); // OK
priority_queue<int> q2(comp, vec); // Fail
return 0;
}
错误消息:
error: no matching function for call to 'std::priority_queue<int>::priority_queue(bool (&)(int, int), std::vector<int>&)'
priority_queue<int> q2(comp, vec);
^
因为(http://de.cppreference.com/w/cpp/container/priority_queue)中的['的默认Compare'模板参数]是'STD: :less'你需要一个不同的模板实例化,而在'sort'中调用比较器类型pe自动推导出来。 – BeyelerStudios