南沙C++信奥老师解一本通题 1371:看病

【题目描述】

有个朋友在医院工作,想请BSNY帮忙做个登记系统。具体是这样的,最近来医院看病的人越来越多了,因此很多人要排队,只有当空闲时放一批病人看病。但医院的排队不同其他排队,因为多数情况下,需要病情严重的人优先看病,所以希望BSNY设计系统时,以病情的严重情况作为优先级,判断接下来谁可以去看病。

【输入】

第一行输入n,表示有n个操作。

对于每个操作,首先输入pushpop

push的情况,之后会输入aiai 和 bibi,分别表示患者姓名和患者病情优先级。

pop后面没有输入,但需要你输出。

【输出】

对于pop的操作,输出此时还在排队人中,优先级最大的患者姓名和优先级。

表示他可以进去看病了。

如果此时没人在排队,那么输出”none”,具体可见样例。

【输入样例】

7
pop
push bob 3
push tom 5
push ella 1
pop
push zkw 4
pop

【输出样例】

none
tom 5
zkw 4

【提示】

【数据规模和约定】

1≤n≤100000,每个人的优先级都不一样,0≤优先级≤2000000000。

姓名都是小写字母组成的,长度小于20。

#include <bits/stdc++.h>
using namespace std;
struct Person
{
	char name[20];
	int level;
	bool operator< (const Person &b ) const
	{
		return b.level>level;
	}
};
int main()
{
	priority_queue<Person> pq;
	int n,level;
	char op[20];
	cin>>n;
	for(int i=1;i<=n;i++)   //所有的都要换成格式化输入输出,否则有一个不通过 
	{
		scanf("%s", op);
	 	if(strcmp(op, "push") != 0)
		{
		   if(pq.empty())
		   		printf("none\n");//cout<<"none"<<endl;
            else
            {
            	Person cur=pq.top();
            	pq.pop();
            	printf("%s %d\n",cur.name,cur.level);  //cout<<cur.name<<" "<<cur.level<<endl;
			}
		}else  //push操作 
		{
			Person newnode;
			scanf("%s%d",&newnode.name,&newnode.level);
			pq.push(newnode);
		}
	}
	return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值