杭电1873题 看病要排队

2024-05-29 19:18
文章标签 杭电 排队 1873 看病

本文主要是介绍杭电1873题 看病要排队,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接~~>

这题是接触优先队列的第二题代码有点。。。

开始做时一直wa,最后才明白应该把 priority_queue<zha>q1;

等放到循环里面去,委屈。。。

代码:

#include<stdio.h>
#include<string.h>
#include<queue>
using namespace std;
struct zha
{int a1;int h1;friend bool operator<(const zha &a,const zha &b){if(a.a1!=b.a1)return a.a1 < b.a1 ;else return a.h1 > b.h1;}};
struct zhan
{int a2;int h2;friend bool operator<(const zhan &a,const zhan &b){if(a.a2!=b.a2)return a.a2 < b.a2 ;else return a.h2 > b.h2;}};
struct zhang
{int a3;int h3;friend bool operator<(const zhang &a,const zhang &b){if(a.a3!=b.a3)return a.a3 < b.a3 ;else return a.h3 > b.h3;}};
int main()
{char s[10];int T,n1,n2;int k;while(scanf("%d",&T)!=EOF){priority_queue<zha>q1;priority_queue<zhan>q2;priority_queue<zhang>q3;zha current1;zhan current2;zhang current3;k=1;while(T--){scanf("%s",s);if(s[0]=='I'){scanf("%d%d",&n1,&n2);if(n1==1){current1.a1=n2;current1.h1=k;q1.push(current1);}else if(n1==2){current2.a2=n2;current2.h2=k;q2.push(current2);}else if(n1==3){current3.a3=n2;current3.h3=k;q3.push(current3);}k++;}else {scanf("%d",&n1);if(n1==1){if(q1.empty()){printf("EMPTY\n");}else {current1=q1.top();printf("%d\n",current1.h1);q1.pop();}}else if(n1==2){if(q2.empty()){printf("EMPTY\n");}else {current2=q2.top();printf("%d\n",current2.h2);q2.pop();}}else if(n1==3){if(q3.empty()){printf("EMPTY\n");}else {current3=q3.top();printf("%d\n",current3.h3);q3.pop();}}}}}return 0;
}

别人代码:

/********************************* *    日期:2013-3-16*    作者:SJF0115 *    题号: HDU 题目1873: 看病要排队*    来源:http://acm.hdu.edu.cn/showproblem.php?pid=1873*    结果:AC *    来源:2008浙大研究生复试热身赛(2)——全真模拟*    总结: 
**********************************/
#include<iostream>
#include<stdio.h>
#include<queue>
using namespace std;struct Patient  
{  //值int priority;//编号int key;  //重载操作符friend bool operator < (Patient p1,Patient p2)  {    if(p1.priority != p2.priority){return p1.priority < p2.priority;}else{return p1.key > p2.key;}}
};int main(){int i,N,k;char Type[4];int DoctorID,PatientID;Patient patient[2001];while(scanf("%d",&N) != EOF){//定义三个医生priority_queue<Patient> Doctor1;priority_queue<Patient> Doctor2;priority_queue<Patient> Doctor3;k = 1;while(N--){scanf("%s",Type);//诊治if(strcmp(Type,"IN") == 0){//输入病人和医生patient[k].key = k;scanf("%d %d",&DoctorID,&patient[k].priority);//排队if(DoctorID == 1){Doctor1.push(patient[k]);}else if(DoctorID == 2){Doctor2.push(patient[k]);}else{Doctor3.push(patient[k]);}k++;}//出院else if(strcmp(Type,"OUT") == 0){//医生DoctorID进行了一次诊治,诊治完毕后,病人出院scanf("%d",&DoctorID);//医生1if(DoctorID == 1){if(Doctor1.empty()){printf("EMPTY\n");}else{printf("%d\n",Doctor1.top().key);//出院Doctor1.pop();}}//医生2else if(DoctorID == 2){if(Doctor2.empty()){printf("EMPTY\n");}else{printf("%d\n",Doctor2.top().key);//出院Doctor2.pop();}}//医生3else{if(Doctor3.empty()){printf("EMPTY\n");}else{printf("%d\n",Doctor3.top().key);//出院Doctor3.pop();}}}}}return 0;
}


别人代码:

#include <cstdio>
#include <algorithm>
#include <queue>using namespace std;struct Node
{int num,id;friend bool operator < (Node a,Node b){if(a.num!=b.num)return a.num<b.num;elsereturn a.id>b.id;}
};
int main()
{int n,A,B,cnt;char str[5];Node t;while(~scanf("%d",&n)){cnt=0;priority_queue <Node>q[4];while(n--){scanf("%s",str);if(str[0]=='I'){scanf("%d%d",&A,&B);t.id=++cnt;t.num=B;q[A].push(t);}else{scanf("%d",&A);if(!q[A].empty()){t=q[A].top();q[A].pop();printf("%d\n",t.id);}elseprintf("EMPTY\n");}}}return 0;
}


 


 

这篇关于杭电1873题 看病要排队的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1014407

相关文章

看病要排队这个是地球人都知道的常识

归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍+ 收藏⭐ + 留言​📝唯有付出,才有丰富的果实收获! 看病要排队这个是地球人都知道的常识。 不过经过细心的0068的观察,他发现了医院里排队还是有讲究的。0068所去的医院有三个医生(汗,这么少)同时看病。而看病的人病情有轻重,所以不能根据简单的先来

Linux进程初识:OS基础、fork函数创建进程、进程排队和进程状态讲解

目录 1、冯诺伊曼体系结构 问题一:为什么在体系结构中存在存储器(内存)? 存储单元总结: 问题二:为什么程序在运行的时候,必须把程序先加载到内存? 问题三:请解释,从你登录上qq开始和某位朋友聊天开始,数据的流动过程。 2、操作系统 2.1操作系统的概念: 我们首先要明白什么是管理: 2.2为什么要有操作系统? 2.3操作系统如何保证稳定和安全呢?(利用系统调用函数解决)

2024杭电8

1004.cats 的重力拼图 题意: 有一个n*m的矩阵,给出最开始拼图的位置。 可以有四个选择,设置重力的方向,就是拼图会向一个方向竖直掉落到最底。 问任意操作次数后拼图走过的方格数量最大值。 题解: 首先已经在边缘的拼图,只能沿着边走一圈,再判断最开始可以朝哪个方向移动是最大值。 代码: #include<bits/stdc++.h>using namespace s

2024杭电6

1001.造花(简单版) 题意: 菊花图:n-1个节点都连接同一节点的树。 给定一棵树,删掉一个节点和连向这个点的所有边,使剩下两个连通块都构成菊花图,问是否可以做到。 题解: 菊花图只有中心节点的度可以没有限制,其余节点的度都是1。 要删除一个节点,要求剩下两个连通块,那就只能删掉度为2的节点,剩下两个菊花图,菊花图最多一个度不是1的节点。 所以度不是1的节点数最多为5,如图。

杭电 1297 Children’s Queue .

http://acm.hdu.edu.cn/showproblem.php?pid=1297   计算F(n): 一:当最后一个是男孩M时候,前面n-1个随便排出来,只要符合规则就可以,即是F(n-1); 二:当最后一个是女孩F时候,第n-1个肯定是女孩F,这时候又有两种情况:         1)前面n-2个可以按n-2个的时候的规则来,完全可以,即是F(n-2);

2014.1.13 杭电习题 绝对值排序

绝对值排序 Problem Description(问题描述) 输入n(n<=100)个整数,按照绝对值从大到小排序后输出。题目保证对于每一个测试实例,所有的数的绝对值都不相等。 Input(输入) 输入数据有多组,每组占一行,每行的第一个数字为n,接着是n个整数,n=0表示输入数据的结束,不做处理。 Output(输出) 对于每个测试实例,输出排序后的结果,两个数之间用一个

2014.1.13 杭电习题 二维字符串中出现数量最多的字符串

Let the Balloon Rise Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submission(s) : 15   Accepted Submission(s) : 6 Font: Times New Roman | Verdana | Georgi

递推—杭电2044 一只小蜜蜂...

http://acm.hdu.edu.cn/showproblem.php?pid=2044 一只小蜜蜂... Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 35811    Accepted Submission(s): 1317

杭电1280 前m大的数(哈希表)

前m大的数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 9557    Accepted Submission(s): 3350 Problem Description 还记得Gardon给小希布置的那个作业么?(上次比赛的1

杭电1867 A + B for you again

Hot~ 2014暑期多校联合训练——正式启动报名~ 详见“杭电ACM”微博~ A + B for you againTime Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 3811    Accepted Submission(s):