std :: priority_queue:自定义排序,不定义比较器类

时间:2010-11-15 16:40:18

标签: c++ boost stl bind priority-queue

我希望有一个具有自定义排序的优先级队列,但是我很懒,我不想定义一个实现operator()的比较器类。

我真的希望编译这样的东西:

std::priority_queue<int, std::vector<int>, 
    boost::bind(some_function, _1, _2, obj1, obj2)> queue;

其中some_function是一个bool返回函数,它带有四个参数,第一个和第二个是队列的整数,最后两个是计算排序所需的一些对象(const引用)。

  

(错误:'boost :: bind'不能出现在常量表达式中)

但是这不能编译。即使是更简单的

std::priority_queue<int, std::vector<int>, &compare> queue;

不会编译,比较是返回bool的二进制函数。

  

(错误:模板参数列表中参数3的类型/值不匹配'模板类std :: priority_queue';期望类型,得到'比较')

有什么建议吗?

1 个答案:

答案 0 :(得分:11)

这可行:

std::priority_queue<int, std::vector<int>, 
    boost::function<bool(int,int)> >

然后将绑定表达式传递给队列的构造函数。

P.S。你得到那些编译错误,因为你将运行时评估的表达式放在需要typename或constant表达式的位置。