【双端队列】例题6-1 UVa 210


 

/*
算法竞赛入门 LRJ 例题6-1(UVa 210)Concurrency Simulator 
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<stack>
#include<map>
#include<queue>
#include<cmath>
#include<algorithm>
#include<deque>
typedef long long LL;
using namespace std;
#pragma comment(linker, "/STACK:102400000,102400000")
const int INF=0x3f3f3f3f;
const int N = 10010;

int mp[10];
int val[30];
int id[N];
string res[N];
deque<int> Q;
deque<int> stop;
int n,q;
int change(string x)
{
    int sum = 0;
    for(int i = 3; i < x.size(); i++)
    {
        if(x[i] >= '0' && x[i] <= '9')
            sum = sum*10+(x[i]-'0');
    }
    return sum;
}
int lock;
void solve(int x)
{
    int time = q;
    while(time > 0)
    {
        string now = res[id[x]];
        //cout << " now " << now << endl;
        if(now[2] == '=')
        {
            val[now[0]-'a'] = change(now);
            time -= mp[0];
        }
        else if(now[2] == 'i')
        {
            printf("%d: %d\n",x,val[now[6]-'a']);
            time -= mp[1];
        }
        else if(now[2] == 'c')
        {
            if(lock == 1)
            {
                stop.push_back(x);
                return ;
            }
            lock = 1;
            time -= mp[2];
        }
        else if(now[2] == 'l')
        {
            if(!stop.empty())
            {
                int temp = stop.front();
                stop.pop_front();
                Q.push_front(temp);
            }
            lock = 0;
            time -= mp[3];
        }
        else
        {
            //End = 1;
            time -= mp[4];
            return ;
        }
        id[x]++;
    }
    Q.push_back(x);
    return ;
}
int main()
{
    int T;
    scanf("%d",&T);
    while(T--)
    {
        scanf("%d%d%d%d%d%d%d",&n,&mp[0],&mp[1],&mp[2],&mp[3],&mp[4],&q);
        memset(val,0,sizeof(val));
        Q.clear();
        stop.clear();
        getchar();
        int num = 0;
        for(int i = 1; i <= n; i++)
        {
            Q.push_back(i);
            getline(cin,res[num++]);
            id[i] = num-1;
            while(res[num-1] != "end")
                getline(cin,res[num++]);
        }
        lock = 0;
        while(!Q.empty())
        {
            int x = Q.front();
            Q.pop_front();
            solve(x);
        }
        if(T)
            puts("");
    }
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值