UvaLive 6440 - Emergency Handling(数据结构)

这篇博客介绍了如何解决UvaLive 6440 - Emergency Handling问题,该问题涉及数据结构的应用。博主提出,通过将病人的病情表示为S(t)=st0-rt0+rt的形式,并对r相同的病人使用优先队列,可以高效地找出病情最严重的病人。在每次操作时,只需枚举优先队列即可找到需要医治的病人。
摘要由CSDN通过智能技术生成

题目链接

UvaLive 6440 - Emergency Handling

题意:输入一个N,n次操作。对于第一种操作增加一个病人,告诉病人的t0,st0,r。第二种操作,在时间t,选取一个病情最严重的病人进行医治。病人的严重情况为S(t)=st0+r(t-t0)。如果病人严重情况相同,选r最大的进行医治。(1<=N <=100 000),(0<=r<=100。对于第二种操作输出被治疗的病人。

我们可以让S(t)函数变一种形式,S(t)=st0-rt0+rt,因为st0-rt0是一个定值,我们把它记为x,那么S(t)=x+r*t.。对于r相同的病人来说随着t的增加他们的相对大小是不会变的,由于r很小,所以我们把r相同的病人放入同一个优先队列,每次询问的时候在枚举每个优先队列,就可以求出s(t)最大的病人。代码如下:


                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值