HDU 1873 优先队列

本文提供了一种使用优先队列解决HDU 1873问题的算法实现,通过为每位医生分配一个优先队列,实现病人的入队(IN)和出队(OUT)操作。代码采用C++编写,详细展示了如何定义节点结构体,并在优先队列中比较节点的优先级。

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1873
在这里插入图片描述
实现方式就是每个医生一个优先队列,IN进队,OUT出队。
AC代码:

#include <iostream>
#include <queue>
using namespace std;
//2020-08-24 10:55:45	Accepted	1873	156MS	1432K	1202 B	G++
struct node{
	int id;
	int rank;
	node(int d, int r): id(d), rank(r) {}
	//这块记一下怎么写
	friend bool operator < (const node& a, const node& b) {
		if(a.rank == b.rank)
			return a.id > b.id;
		return a.rank < b.rank;
	}
};

priority_queue<node> q1, q2, q3;

int main() {
	int n, A, B;
	string op;
	while(cin>>n) {
		int cnt = 0;
		//清空优先队列
		while(!q1.empty())	q1.pop();
		while(!q2.empty())	q2.pop();
		while(!q3.empty())	q3.pop();
		
		for(int i=1; i<=n; i++) {
			cin>>op;
			if(op == "IN") {
				cnt++;
				cin>>A>>B;  //一拥有优先级B的病人要求医生A诊治
				if(A == 1)	q1.push(node(cnt, B));
				else if(A == 2)	q2.push(node(cnt, B));
				else	q3.push(node(cnt, B));
			}
			else {
				cin>>A;
				if(A == 1) {
					if(!q1.empty()) {
						cout<<q1.top().id<<endl;
						q1.pop(); 
					}
					else
						cout<<"EMPTY"<<endl;
				}
				else if(A == 2) {
					if(!q2.empty()) {
						cout<<q2.top().id<<endl;
						q2.pop(); 
					}
					else
						cout<<"EMPTY"<<endl;
				}
				else if(A == 3) {
					if(!q3.empty()) {
						cout<<q3.top().id<<endl;
						q3.pop(); 
					}
					else
						cout<<"EMPTY"<<endl;
				}
			}
			
		}
	}
	
	return 0;
} 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值