Uva 6440 - Emergency Handling 多个优先队列维护

原创 2013年12月01日 22:40:28

               题意:

                        再一个二维平面内,不断的有射线插入(1<=N<=100000)..同时也会在某些x处询问这些射线中最大的y值...请输出这些y值...

               题解:

                        突破口在题目给出了斜率范围是[1,100]的整数.. 所以可以构造100个优先队列..优先级是在这个斜率下..y值大...那么每次要么就是往100个中某个优先队列丢入一个线..要么是输出..找出这100个中..栈顶y最大的..然后将其弹栈...


Program:

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <cmath>
#include <queue>
#include <string.h>
using namespace std;
typedef long long ll;
priority_queue<int> Q[102];
int main()
{
      int C,cases,n,t,s,r,num,w,temp,h,data;
      char c; 
      scanf("%d",&C);
      for (cases=1;cases<=C;cases++)
      {
              scanf("%d",&n);
              for (r=0;r<=100;r++)
                 while (Q[r].size()) Q[r].pop();
              printf("Case #%d:\n",cases);
              num=0;
              while (n--)
              {
                      do
                      {
                            c=getchar();
                      }while (c!='P' && c!='A');
                      if (c=='P')
                      {
                            scanf("%d%d%d",&t,&s,&r);
                            s-=t*r;
                            Q[r].push(s);
                      }else
                      {
                            data=-(1<<30);
                            scanf("%d",&t);
                            for (r=0;r<=100;r++)
                               if (Q[r].size())
                               {
                                      h=Q[r].top();
                                      temp=h+t*r;
                                      if (temp>=data)
                                      {
                                             data=temp;
                                             w=r;
                                      }
                               }
                            h=Q[w].top(),Q[w].pop();
                            printf("%d %d\n",h+t*w,w);
                      }
              }
      }
      return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

UVALive 6440 Emergency Handling 优先队列

题目连接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&...

UVA 6440 Emergency Handling 队列

一家医院比较繁忙,病人需要排队,病人有个病重程度

UvaLive 6440 - Emergency Handling(数据结构)

题目链接 UvaLive 6440 - Emergency Handling 题意

Beijing 2004 / UVa 1203 / UVALive 3135 / ZOJ 2212 Argus (优先队列)

Argus Time Limit: 2 Seconds      Memory Limit: 65536 KB A data stream is a real-time, continuous, ...

UVa 10047 - The Monocycle 优先队列+BFS

A monocycle is a cycle that runs on one wheel and the one we will be considering is a bit more speci...
  • FTQOOO
  • FTQOOO
  • 2016年04月15日 17:59
  • 194

UVA 11997 K Smallest Sums(优先队列)

题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem...

(advanced) UVA 优先队列+贪心 1316 Supermarket

A supermarket has a set Prod of products on sale. It earns a profit px for each product x in Prod so...

Uva-7423-Assigning Workstations(贪心+优先队列)

链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&pr...

uva 10537 Toll! Revisited(优先队列优化dijstra及变形)

Toll! Revisited 大致题意:有两种节点,一种是大写字母,一种是小写字母。首先输入m条边,当经过小写字母时需要付一单位的过路费,当经过大写字母时,要付当前财务的1/20做过路费。问在起点...

UVa 10050 Hartals(优先队列)

10050 - Hartals Time limit: 3.000 seconds http://uva.onlinejudge.org/index.php?option=com_onlinejudg...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Uva 6440 - Emergency Handling 多个优先队列维护
举报原因:
原因补充:

(最多只允许输入30个字)