实现此自定义priority_queue的正确方法是什么
What is the correct way of implementing this custom priority_queue
我想建立一个对象的优先级队列,该队列具有三个具有我自己的比较器的元素。我尝试了以下代码,但显示错误.
#include<bits/stdc++.h>
using namespace std;
class triplet {
public:
int data;
int arr;
int index;
};
bool compare( triplet x, triplet y ){
if(x.data < y.data){
return true;
}
else{
return false;
}
}
int main(){
priority_queue<triplet,vector<triplet>,compare> pq1;
}
收到以下错误 在此处输入图像描述
如果两个元素相等,则比较例程必须返回 false,但您的版本返回 true。
试试这个
bool compare(triplet x, triplet y) {
if (x.data < y.data) {
return true;
}
else {
return false;
}
}
或者像这样让它更简单一点
bool compare(triplet x, triplet y) {
return x.data < y.data;
}
但重要的一点是<
不是<=
.
编辑
您的代码也不正确地使用了compare
。compare
不是一种类型,因此它不是 priority_queue 模板的有效参数。
compare
的类型是bool (*)(triplet, triplet)
,因此正确的方法是在模板中使用该类型并将实际的比较函数传递给构造函数。喜欢这个
priority_queue<triplet, vector<triplet>, bool (*)(triplet, triplet)> pq1(compare);
顺便说一句,通常您会通过创建比较函子而不是函数来做到这一点。这样更干净(并且可能更有效(。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 通过JNI传递数据数组的最快方法是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么
- 当无法使用模板和宏时,生成类型变体C++代码的最简单方法是什么?
- 在另一个类视图中添加最多2个图表的正确方法是什么
- 在C++中样板"冷/never_inline"错误处理技术的最佳方法是什么?
- 在 c++ 中对类中的 c 字符串动态数组进行排序的最佳方法是什么?
- 在C++中包含原型文件的正确方法是什么?
- 在 OpenCV C++ 中估计基本矩阵之前对相应点进行归一化的正确方法是什么?
- 在PostgreSQL中根据它们的ID选择大量行的最快方法是什么?
- 在OSX上使用CMake将Adobe的XMP工具包构建为共享库的最简单方法是什么?
- 将一系列整数放入类的最佳方法是什么?
- 从长整整转换为uint64_t的推荐方法是什么?
- 将此布尔值传递给此函数的最有效方法是什么?
- 通过比较C++中的行在 txt 文件中搜索的最简单方法是什么?