参考资料:
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() | 判断优先队列是否为空 |
原文链接: https://www.cnblogs.com/shiokiri/p/10183347.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/287642
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!