c++构造函数中使用带参数的Comparator自定义类的优先级队列
Priority Queue of custom Class using Comparator with argument on constructor in C++
我想在c++中创建Edge
类的priority_queue
。
edgeCompare
比较器类,如下所示:
class edgeCompare{
public:
map<int, glm::mat4x4> * Qmap;
edgeCompare(const map<int, glm::mat4x4> & Qm){
* Qmap = Qm;
}
bool operator() (const Edge & e1, const Edge & e2) const{
// code that compares and returns corresponding bool
// OBS: in this function I use *Qmap
}
}
问题是,正如你所看到的,我需要一个外部变量来进行比较。
priority_queue
通常声明为:
priority_queue<Edge, vector<Edge>, edgeCompare> pq;
但是在我的例子中,我需要用变量Qmap
来构造edgeComparator
。
我该怎么做?
非常感谢!
模板参数是比较器的类型。您仍然需要将比较器的实例传递给priority_queue构造函数,这时您可以使用您喜欢的任何参数构造比较器实例。
例如:map<int, glm::mat4x4> m;
edgeCompare comp(m);
priority_queue<Edge, vector<Edge>, edgeCompare> pq(comp);
您也可以内联创建edgeCompare
对象,但需要额外的括号来消除歧义:
priority_queue<Edge, vector<Edge>, edgeCompare> pq((edgeCompare(m)));
在Edge
类中重载operator==
, operator!=
, operator>
和operator<
,以便您可以在比较器中比较它们e1 == e2
。
也不要从std::map
派生。它没有virtual
析构函数,这使得从它派生是一个坏主意。
将map作为类的私有成员
根据这里的链接,有一个重载允许您在priority_queue
的构造函数中传递谓词。
相关文章:
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 如何将点击的信号和插槽添加到qt中的自定义按钮中
- C++自定义比较函数
- 如何比较自定义类的std::变体
- std::设置自定义比较器
- 如何正确实现和访问运算符的各种自定义枚举器
- flutter:即使shouldRepaint()返回true,自定义画家也不会重新绘制
- 自定义先决条件对移动分配运算符有效吗
- 使用VS Code和CMake Tools运行自定义命令
- 如何创建从Maya(或类似程序)到虚幻引擎的自定义数据导出插件
- std::ranges::elements_view,用于自定义类似元组的数据
- 跟随整数索引列表的自定义类迭代器
- 参数化自定义CMake工具链
- 使用自定义比较函数使用std::sort()对矢量字符串进行排序时出现问题
- 如何在自定义类中启用'auto loops'?
- 使用QJsEngine在Qt中注册自定义类型
- Qt自定义QPush按钮未显示在布局上
- 自定义对象的dlib序列化在gcc中失败
- 错误:使用自定义比较功能排序时"invalid comparator"
- c++构造函数中使用带参数的Comparator自定义类的优先级队列