priority_queue使用降序向量实现最小堆的语法差异
Syntax difference of priority_queue implementing min heap with descending sort of vector
使用 STL 实现最小堆priority_queue语法是
std::priority_queue<int, std::vector<int>, std::greater<int> > my_min_heap;
而按降序实现向量sort()
的语法为
sort(a.begin(), a.end(), greater<int>());
我的问题是排序使用((在更大之后,但priority_queue没有。为什么?
这里
std::priority_queue<int, std::vector<int>, std::greater<int> > my_min_heap;
std::greater<int>
是模板参数,请注意它位于<>
.它是一种类型。另一方面,这里
sort(a.begin(), a.end(), greater<int>());
将创建该类型的实例并将其传递给sort
。此外,sort
具有比较器的模板参数,但它是从参数(类型为std::greater<int>
(推导出来的,因此无需显式指定它。
更具体地说std::greater<int>
是一个函子,即对函数调用运算符具有重载的类型。要创建一个实例并使用它来比较两个int
,您可以编写:
bool x = std::greater<int>()(5,3);
/* the type */
// ^ call constructor
// ^ call the objects operator()
但是,通常相同的函数对象被重用于许多比较,就像std::sort
一样。
相关文章:
- 解释通过 lex/flex 实现 C/C++嵌套的"#include "Header""语法?
- priority_queue使用降序向量实现最小堆的语法差异
- 如何在编译器C++不智能的情况下实现 GLSL vec* 构造语法?
- 如何使用 Boost.Asio 正确实现异步/等待语法
- 像这样的PIMPL实现是否有任何简单的语法
- 在任何编译语言中实现以下语法(用于工厂设计模式)? 最好是 Kotlin,C++
- 如何使用自然外观的语法实现线程安全容器
- 在C 中,可以用语法[i,j,..]实现访问数组元素的功能,而语法就像numpy中的ndarray样式一样
- 我不理解这个dfs实现的语法
- 如何使用两个单独的语法实现计算机翻译器
- 强类型枚举的语法实现错误
- GCC 4.4 不实现 C++11 范围循环.它还支持哪些其他范围循环语法
- 模板的赋值运算符(成员函数)实现的正确语法
- 实现功能齐全的移位流语法
- 用C++实现Matlab语法
- 在不使用专用语法的情况下,为不同类型的不同方式实现模板类的方法是否有效C++?
- Boost是如何实现这样的语法的
- 在我的解释器上为脚本代码实现语法检查器的最佳方式是什么
- 实现图,节点/类语法c++
- 尝试为特征矩阵实现一种初始化列表语法