Description
看病要排队这个是地球人都知道的常识。
不过经过细心的0068的观察,他发现了医院里排队还是有讲究的。0068所去的医院有三个医生(汗,这么少)同时看病。而看病的人病情有轻重,所以不能根据简单的先来先服务的原则。所以医院对每种病情规定了10种不同的优先级。级别为10的优先权最高,级别为1的优先权最低。医生在看病时,则会在他的队伍里面选择一个优先权最高的人进行诊治。如果遇到两个优先权一样的病人的话,则选择最早来排队的病人。
现在就请你帮助医院模拟这个看病过程。
Input
输入数据包含多组测试,请处理到文件结束。
每组数据第一行有一个正整数N(0
#include <cstdio>
#include <queue>
#include <cstring>
using namespace std;
#define M 2200
struct node//目前所知,优先队列要用数据结构来定义
{
int lev;
int rank;
friend bool operator <(node t1, node t2)
{
if(t1.lev == t2.lev)
{
return t1.rank > t2.rank;//这里的大小之比可以理解为,把大的放的离自己近,然而队列的顶部在远方
}
return t1.lev < t2.lev;
}
};
node no[M];
int main()
{
int n, a, b;
char ch[5];
while(scanf("%d", &n) != EOF)
{
int k = 1;
priority_queue<node> doc1;//优先队列的定义
priority_queue<node> doc2;
priority_queue<node> doc3;
for(int i=1; i<=n; i++)
{
scanf("%s", ch);
if(!strcmp(ch, "IN"))
{
scanf("%d%d", &a, &no[k].lev);
no[k].rank = k;
if(a == 1)
{
doc1.push(no[k]);
}
else if(a == 2)
{
doc2.push(no[k]);
}
else
{
doc3.push(no[k]);
}
k++;
}
else
{
scanf("%d", &a);
if(a == 1)
{
if(!doc1.empty())
{
printf("%d\n", doc1.top().rank);
doc1.pop();
}
else
{
printf("EMPTY\n");
}
}
else if(a == 2)
{
if(!doc2.empty())
{
printf("%d\n", doc2.top().rank);
doc2.pop();
}
else
{
printf("EMPTY\n");
}
}
else
{
if(!doc3.empty())
{
printf("%d\n", doc3.top().rank);
doc3.pop();
}
else
{
printf("EMPTY\n");
}
}
}
}
}
return 0;
}