onecode第一届一码学程正式邀请赛B 排队找bug

## 10222 : 排队找bug ##

时间限制: 1000 MS 内存限制: 131072 KB 提交总数: 125 AC总数: 24
问题描述
同学们的bug还真是多啊,orz…
春节期间大家存下的bug都来找肖老师解决了。
每个人都有bug,但是肖老师却只有一个啊。怎么办?
所以肖老师让大家按先来后到的顺序排队,一个一个的给大家解决。
这不一大早起来,肖老师就等着同学们过来解决bug了。不过肖老师偶尔想知道当前队伍中bug数量最少的是多少bug。
sos xbug操作表示有一个同学有x个bug,并且过来排队等待肖老师解决。
ok 操作表示肖老师已经解决了排在队伍最前面同学的所有bug。
min 操作表示肖老师需要知道当前排队队伍中bug数量最少的是多少bug。
输入格式
第一行输入一个正整数n,表示总共有n总操作。
接下来输入n行,每行一种操作。
【限制条件】
1≤n≤10^6
每个人的bug数量不超过1000000。

注意,数据大到用必须得用scanf,printf输入输出
输出格式
对于每一次min操作,输出当前排队中bug最少的数量。
如果执行min(或者ok)操作时,当前队伍为空,则输出“So happy!no bug!”。
样例输入
7
sos 6bug
sos 7bug
min
ok
min
ok
min
样例输出
6bug
7bug
So happy!no bug!


#include
using namespace std;
queue<int> que;  
deque<int> minque;  
deque<int> maxque;  
void push(int val)  
{  
    que.push(val);  
    while ((!minque.empty()) && (minque.back() > val))  
        minque.pop_back();  
    minque.push_back(val);  
    while ((!maxque.empty()) && (maxque.back() < val))  
        maxque.pop_back();  
    maxque.push_back(val);  
}  
void pop()  
{  
    int value = que.front();  
    que.pop();  
    if (!minque.empty() && minque.front() == value)  
        minque.pop_front();  
    if (!maxque.empty() && maxque.front() == value)  
        maxque.pop_front();  
}  
int findmin()  
{  
    return minque.front();  
}  
int findmax()  
{  
    return maxque.front();  
}  
int main()
{
    int n;
    scanf("%d",&n);
    while(n--)
    {
        char op[10];
        scanf("%s",op);
        int x;
        if(op[0]=='s') 
        {
            scanf("%dbug",&x);
            push(x);
        }
        else if(op[0]=='m')
        {
            if(que.size()==0 || minque.empty()) printf("So happy!no bug!\n");
            else printf("%dbug\n",findmin());
        }
        else 
        {
            if(que.size()==0 || minque.empty()) printf("So happy!no bug!\n");
            else pop();
        }
    }
    return 0;
}

你可能感兴趣的:(onecode第一届一码学程正式邀请赛B 排队找bug)