双向队列 STL

题目描述

      想想双向链表……双向队列的定义差不多,也就是说一个队列的队尾同时也是队首;两头都可以做出队,入队的操作。
现在给你一系列的操作,请输出最后队列的状态;
命令格式:
LIN X  X表示一个整数,命令代表左边进队操作;
RIN X  表示右边进队操作;
ROUT
LOUT   表示出队操作;

输入

第一行包含一个整数M(M<=10000),表示有M个操作;
以下M行每行包含一条命令;
命令可能不合法,对于不合法的命令,请在输出中处理;

输出

输出的第一行包含队列进行了M次操作后的状态,从左往右输出,每两个之间用空格隔开;
以下若干行处理不合法的命令(如果存在);
对于不合法的命令,请输出一行X ERROR
其中X表示是第几条命令;

示例输入

8
LIN 5
RIN 6
LIN 3
LOUT
ROUT
ROUT
ROUT
LIN 3

示例输出

3
7 ERROR
 1 #include<cstdio>
 2 #include<iostream>
 3 #include<string.h>
 4 #include<queue>
 5 using namespace std;
 6 
 7 int main()
 8 {
 9     int n,wrong[101],c,x;
10     char s[10];
11     deque<int>dque;
12     c = 0;
13     scanf("%d",&n);
14     for(int i = 1; i <= n; i++)
15     {
16         scanf("%s",s);
17         if(strcmp(s,"LIN") == 0)
18         {
19             scanf("%d",&x);
20             dque.push_front(x);
21         }
22         else if(strcmp(s,"RIN") == 0)
23         {
24             scanf("%d",&x);
25             dque.push_back(x);
26         }
27         else if(strcmp(s,"LOUT") == 0)
28         {
29             if(dque.empty())
30             {
31                 wrong[c++] = i;
32                 continue;
33             }
34             else
35             {
36                 dque.pop_front();
37             }
38         }
39         else if(strcmp(s,"ROUT") == 0)
40         {
41             if(dque.empty())
42             {
43                 wrong[c++] = i;
44                 continue;
45             }
46             else
47             {
48                 dque.pop_back();
49             }
50         }
51     }
52     printf("%d",dque.front());
53     dque.pop_front();
54     while(!dque.empty())
55     {
56         printf(" %d",dque.front());
57         dque.pop_front();
58     }
59     printf("\n");
60     for(int i = 0; i < c; i++)
61     {
62         printf("%d ERROR\n",wrong[i]);
63     }
64 
65     return  0;
66 }
View Code

 

posted on 2013-06-22 20:55  straw_berry  阅读(287)  评论(0编辑  收藏  举报