multimap和priority_queue的默认排序问题
两者默认的都是less模式,但
1.multimap构造multimap<T1, T2>时,其实是有个默认的比较函数 multimap<T1, T2, less> ,即按key的升序排列
2.priority_queue默认的也是less模式,但是大顶堆即降序排列
定义:priority_queue<Type, Container, Functional>
Type 就是数据类型,Container 就是容器类型(Container必须是用数组实现的容器,比如vector,deque等等,但不能用 list。STL里面默认用的是vector),Functional 就是比较的方式。
当需要用自定义的数据类型时才需要传入这三个参数,使用基本数据类型时,只需要传入数据类型,默认是大顶堆。
优先队列具有队列的所有特性,包括队列的基本操作,只是在这基础上添加了内部的一个排序,它本质是一个堆实现的。
首先要包含头文件#include, 他和queue不同的就在于我们可以自定义其中数据的优先级, 让优先级高的排在队列前面,优先出队。
和队列基本操作相同:
top 访问队头元素
empty 队列是否为空
size 返回队