队列(queue) <queue>
先进先出的执的排列 <queue>
定义一个queue的变量 queue<Type> M
查看是否为空范例 M.empty() 是的话返回1,不是返回0;
从已有元素后面增加元素M.push()
输出现有元素的个数 M.size()
显示第一个元素 M.front()
显示最后一个元素 M.back()
清除第一个元素 M.pop()
优先队列(priority_queue) <queue>
元素的次序是由作用于所存储的值对上的某种谓词决定的的一种队列 <queue>
1、默认从大到小
priority_queue<int> qi;
2、从小到大输出可以传入一个比较函数,使用functional.h函数对象作为比较函数,great<int>(小到大) less<int>(大到小)
priority_queue<int, vector<int>, greater<int> >qi2; 第二个参数为容器类型。第三个参数为比较函数。
3、自定义:
struct cmp // 最小优先队列
{
bool operator()(const long long i,constlong long j)
{
return i>j;
}
};
priority_queue<int,vector<longlong>,cmp> Q;
struct node // 最小优先队列
{
int id,len;
bool operator < (const node &b)const// 只能重载小于号
{
return len>b.len;
}
};
priority_queue<node>Q;
Q.empty() // 判断队列是否为空返回ture表示空返回false表示空 bool
Q.top() // 返回顶端元素的值元素还在队列里
Q.pop() // 删除顶端元素 void
Q.push(V) // 把long long型的数V加入到队列里它会制动条件V的位置void
Q.size() // 返回队列里元素个数 unsigned int
双端队列(deque) <deque>
连续存储的指向不同元素的指针所组成的数组<deque>
deque<int>c
c.pop_back() 删除最后一个数据。
c.pop_front() 删除头部数据。
c.push_back(elem) 在尾部加入一个数据。
c.push_front(elem) 在头部插入一个数据。
c.clear() 移除容器中所有数据。
c.front() 传回地一个数据。
c.back() 传回最后一个数据,不检查这个数据是否存在。
c.size() 返回容器中实际数据的个数。
c.empty() 判断容器是否为空。
c[i] 等同于 c.at(i);