【C++】优先级队列以及仿函数

本篇我们来介绍一下优先级队列 priority_queue 。优先级队列的底层是数据结构中的,在C++中它是一个容器适配器,这个容器适配器比之前的栈和队列更复杂。

1.priority_queue的介绍

1.1 优先级队列的底层

因为优先级队列就是堆,堆的底层是数组,所以优先级队列的默认适配器也是数组

 需要用到访问下标的,数组一定是最好的选择。不了解堆的,建议先看下面这篇博客。

 数据结构中的堆:【数据结构】堆的概念、结构、模拟实现以及应用

1.2 文档介绍

文档介绍:priority_queue - C++ Reference

在C++中优先级队列的相关接口就是如上这些。这里的top,如果大的值优先级高,也就是大堆,top返回的就是堆里面的最大值,如果是小的数优先级高,也就是小堆,返回的就是最小值。

2.priority_queue的使用

使用优先级队列的时候需要包含头文件 #include <queue>

	priority_queue<int> pq;
	pq.push(5);
	pq.push(2);
	pq.push(1);
	pq.push(10);
	pq.push(8);
	pq.push(4);

数据结构中的实现逻辑如下。 用到的是向上调整算法。

 再通过top和pop的配合,把这些数打印出来。

while (!pq.empty())
{
	cout << pq.top() << " ";
	pq.pop();
}
cout << endl;

 优先级队列默认大的值优先级高,在数据结构中的意思就是,默认为大堆。

如果想换成小的优先级高,就是小堆,我们就要传greeter

priority_queue<int, vector<int>, greater<int>> pq;

改成greater,用同样的用例试试。

结果就是升序排列。 

 在数据结构中小堆就是要用到

评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值