[C++] stack和queue的常用函数

参考资料:
STL 在 OI 中的应用

stack

stack 后入先出(LIFO)栈

头文件:

#include<stack>

定义:

stack<int> s;

函数:

函数 功能
q.top() 获取栈顶元素(并不删除)
q.pop() 删除栈顶元素
q.push(x) 向栈中加入元素
q.empty() 判断栈是否为空

queue

queue 先入先出(FIFO)队列

头文件:

#include<queue>

定义:

queue<int> q;

函数:

函数 功能
q.front() 获取队首元素(并不删除)
q.pop() 删除队首元素
q.push(x) 向队列中加入元素
q.empty() 判断队列是否为空

priority_queue 优先队列

头文件:

#include<queue>

定义:

priority_queue<int> q; // 队头最大
priority_queue<int,vector<int>,greater<int> > q; 队头最小

函数:

函数 功能
q.top() 获取优先队列中最大的元素(并不删除),其时间复杂度为\(O(1)\)
q.pop() 删除优先队列中最大元素,其时间复杂度为\(O(log n)\)
q.push(x) 向优先队列中加入元素,其时间复杂度为\(O(log n)\)
q.empty() 判断优先队列是否为空
posted @ 2018-12-27 10:01  Shiokiri  阅读(2064)  评论(0编辑  收藏  举报