一,概述

         先进先出的数据结构,底端加入元素,顶端移除元素,类似stack同样不能有遍历行为,没有迭代器。也是以既有容器为底端容器被归类为陪接器(container adapter),默认底端容器为deque。

二,使用

         #include <queue>

          using namespace std;

三,方法

queue::push( );       //底部插入元素
queue::pop( );         //顶端移除元素
queue::empty( );     //是否为空
queue::back( );      
queue::front( );
queue::size( );

四,示例

#include <list>
#include <iostream>
#include <queue>
#include <deque>
using namespace std ;

// Using queue with list
typedef list<int > INTLIST;
typedef queue<int,INTLIST>  INTQUEUE;


// Using queue with deque
typedef deque<const char*> CHARDEQUE;
typedef queue<const char*,CHARDEQUE> CHARQUEUE;


int main(void)
{
    size_t size_q;
    INTQUEUE q;
    CHARQUEUE p;


    // Insert items in the queue(uses list)
    q.push(42);
    q.push(100);
    q.push(49);
    q.push(201);

    size_q = q.size();
    cout << "size of q is:" << size_q << endl;

    while (!q.empty())
    {
        cout << q.front() << " ";
        q.pop();
    }


    p.push("cat");
    p.push("ape");
    p.push("dog");
    p.push("mouse");
    p.push("horse");

    cout << "\n"<<"p.back:"<<p.back() << endl;//the last elemet
    size_q = p.size();
    cout << "size of p is:" << size_q << endl;

    while (!p.empty())
    {
        cout << p.front() <<" ";
        p.pop();
    }
}



Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐