STL之deque

Posted 极限之旅

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了STL之deque相关的知识,希望对你有一定的参考价值。

描述

使用STL中的deque,完成入队、出队、获取队首、获取队尾等基本操作。

部分代码已经给出,请补充完整,提交时请勿包含已经给出的代码。

 

int main()
{
    deque<int> qu;
    int n;
    cin>>n;
    while(n--)
    {
        Op(qu);
    }
    deque<int>::iterator it;
    for(it=qu.begin();it!=qu.end();it++)
        cout<<*it<<endl;
    return 0;
}

输入

输入数据第一行为整数n,接下来有n个命令,其中命令格式:

(1)队尾入队:pushb x

(2)队首入队:pushf x

(3)队尾出队:popb

(4)队首出队:popf

(3)清空:clear

(4)获得队首并输出:first

(5)获得队尾并输出:last

如果部分操作无效,该操作不执行。

输出

操作过程中若有输出,每行一个元素,执行一系列操作后,输出从队首到队尾的所有元素值,每行一个。

样例输入

 9
pushb 1
pushf 2
popb
popf
pushf 3
pushb 4
pushb 5
first
last

样例输出

 3
5
3
4
5

#include <iostream>
#include <string>
#include <stack>
#include <deque>
using namespace std;
void Op(deque<int> &qu)
{
    string ss;
    cin>>ss;
    if(ss=="pushb")
    {
        int n;
        cin>>n;
        qu.push_back(n);
     }
     else if(ss=="pushf")
     {
         int n;
         cin>>n;
         qu.push_front(n);
     }
     else if(ss=="clear")
     {
         qu.clear(); 
     }
     else if(ss=="popb")
     {
         if(!qu.empty())
         {
             qu.pop_back();
         }
     }
     else if(ss=="popf")
     {
         if(!qu.empty())
         {
             qu.pop_front();
         }
     }
     else if(ss=="first")
     {
         if(!qu.empty())
         {
             cout<<qu.front()<<endl;
         }
     }
     else {
         if(!qu.empty())
         {
             cout<<qu.back()<<endl;
         }
     }
}
int main()
{
    deque<int> qu;
    int n;
    cin>>n;
    while(n--)
    {
        Op(qu);
    }
    deque<int>::iterator it;
    for(it=qu.begin();it!=qu.end();it++)
        cout<<*it<<endl;
    return 0;
}

 

 

以上是关于STL之deque的主要内容,如果未能解决你的问题,请参考以下文章

stl之deque双端队列容器

C++ STL 之 deque

STL之Deque

STL之deque使用详解

STL之deque用法

STL之deque