hdu1873 看病要排队(结构体优先队列)
看病要排队
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 5769 Accepted Submission(s): 2369
只是经过细心的0068的观察,他发现了医院里排队还是有讲究的。
0068所去的医院有三个医生(汗,这么少)同一时候看病。而看病的人病情有轻重,所以不能依据简单的先来先服务的原则。所以医院对每种病情规定了10种不同的优先级。
级别为10的优先权最高。级别为1的优先权最低。
医生在看病时,则会在他的队伍里面选择一个优先权最高的人进行诊治。假设遇到两个优先权一样的病人的话,则选择最早来排队的病人。
如今就请你帮助医院模拟这个看病过程。
每组数据第一行有一个正整数N(0<N<2000)表示发生事件的数目。
接下来有N行分别表示发生的事件。
一共同拥有两种事件:
1:"IN A B",表示有一个拥有优先级B的病人要求医生A诊治。(0<A<=3,0<B<=10)
2:"OUT A",表示医生A进行了一次诊治,诊治完成后,病人出院。(0<A<=3)
诊治人的编号ID的定义为:在一组測试中,"IN A B"事件发生第K次时,进来的病人ID即为K。
从1開始编号。
7
IN 1 1
IN 1 2
OUT 1
OUT 2
IN 2 1
OUT 2
OUT 1
2
IN 1 1
OUT 1
2
EMPTY
3
1
1
pid=1509" target="_blank" style="color:rgb(26,92,200); text-decoration:none">1509
1872pid=1876" target="_blank" style="color:rgb(26,92,200); text-decoration:none">1876
pid=1874" target="_blank" style="color:rgb(26,92,200); text-decoration:none">1874
pid=1873" style="color:rgb(26,92,200); text-decoration:none">Statistic
用队列模拟看病过程就好啦 。
。
。为什么我的眼里有了泪水。。
由于我链表不会。。。
#include <stdio.h>
#include <queue>
using namespace std;
struct node
{
int x,num;
friend bool operator<(node a,node b)//先对病人的优先级排序,假设相等再对编号排序
{
if(a.x<b.x) return true;
if(a.x==b.x&&a.num>b.num) return true;
return false;
}
};
priority_queue<node>s1;//
priority_queue<node>s2;//
priority_queue<node>s3;//哈哈 用了三个。 。。
int main()
{
int n,mark[2005];
char str[10];
while(scanf("%d",&n)!=EOF)
{
while(!s1.empty())
s1.pop();
while(!s2.empty())
s2.pop();
while(!s3.empty())
s3.pop();
int q=0,a,b,t=1;
for(int i=0;i<n;i++)
{
scanf("%s",str);
if(str[0]=='I')//假设IN
{
node temp;
scanf("%d %d",&a,&b);
temp.num=t++,temp.x=b;
if(a==1)
s1.push(temp);
else if(a==2)
s2.push(temp);
else
s3.push(temp);
}
else//假设OUT,用一个mark数组记录一下序号病人,当然,假设队列为空。记录为0
{
node temp;
scanf("%d",&a);
if(a==1)
{
if(!s1.empty())
{
temp=s1.top(),s1.pop();
mark[q++]=temp.num;
}
else
mark[q++]=0;
}
else if(a==2)
{
if(!s2.empty())
{
temp=s2.top(),s2.pop();
mark[q++]=temp.num;
}
else
mark[q++]=0;
}
else
{
if(!s3.empty())
{
temp=s3.top(),s3.pop();
mark[q++]=temp.num;
}
else
mark[q++]=0;
}
}
}
for(int i=0;i<q;i++)//推断mark【i】数值输出
{
if(mark[i]==0)
printf("EMPTY\n");
else
printf("%d\n",mark[i]);
}
}
return 0;
}
hdu1873 看病要排队(结构体优先队列)的更多相关文章
- HDU1873 看病要排队【模拟+优先队列】
看病要排队 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- hdu1873 看病要排队【优先队列】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1873 看病要排队 Time Limit: 3000/1000 MS (Java/Others) ...
- hdu1873 看病要排队 优先队列
看病要排队 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Status ...
- hdu 1872(看病要排队)(优先队列)
看病要排队 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- HDU-1873 看病要排队(队列模拟)
看病要排队 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- HDU1873 看病要排队 —— 优先队列(STL)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1873 题解: 题目已经说出了解题方法:优先队列.但是之前没有学过优先队列,而且这题还是在现场赛做的.由 ...
- hdu1873-看病要排队-(结构体优先队列)
http://acm.hdu.edu.cn/showproblem.php?pid=1873 #include<stdio.h> #include<iostream> #inc ...
- hdoj 1873 看病要排队【优先队列】
看病要排队 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- hdu1837 看病要排队(优先队列)
看病要排队 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
随机推荐
- OpenCV2:第七章 图像处理
一.简介 灰度图(灰阶图),把白色到黑色之间分为256阶灰度 彩色图有RGB三个分量,假设图是800*800像素,那么就有三个800*800的矩阵分别代表RGB 二值化处理设定阈值,在阈值中的像素值变 ...
- nginx+tomcat实现简单的负载均衡
host1:10.0.0.10(部署nginx和tomcat) host2:10.0.0.11(部署tomcat) 平台环境(2主机一样) [root@smp ~]# uname -r3.10.0-8 ...
- python的2种字符串格式化输出
字符串格式化代码(typecode) 法一: %格式使用下面的格式 %[(name)] [flags] [width][.precision] typecode (name)输出字典的value使用, ...
- Go:sync.Once 实现单例模式
代码: package main import ( "fmt" "sync" ) type Singleton struct{} var singleton * ...
- 《Java编程思想》笔记14.类型信息
运行时类型信息使得你可以在运行时发现和使用类型信息,主要有两种方式: "传统的"RTTI,它假定我们在编译时已经知道了所有的类型: "反射"机制,它允许我们在运 ...
- python中的函数的分类
函数的种类 传参的基本要求 默认参数 *args 关键字参数 **kwargs 普通函数 带参数 默认参数 def text(a,b=2) print("haha") print( ...
- os操作文件
os.makedirs('dirname1/dirname2') 可生成多层递归目录 os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依 ...
- reversing.kr easykeygen 之wp
补充: int(x,[base]): 就是将x(通常是一个字符串)按照base进制转换成整数. 比如: ’) ##转换成整数10 ) ##'按16进制转换,将得到整数16 ) ##得到255 int( ...
- Device eth0 does not seem to be present,delaying initialization问题
1.打开/etc/udev/rules.d/70-persistent-net.rules: cat /etc/udev/rules.d/70-persistent-net.rules 文件内容如图: ...
- 04004_使用JavaScript完成注册表单数据校验
1.需求分析 (1)用户在进行注册的时候会输入一些内容,但是有些用户会输入一些不合法的内容,这样会导致服务器的压力过大,此时我们需要对用户输入的内容进行一个校验(前端校验和后台校验): (2)前端校验 ...