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&...
  • u010008539
  • u010008539
  • 2014年08月11日 12:06
  • 395

UVA 6440 Emergency Handling 队列

一家医院比较繁忙,病人需要排队,病人有个病重程度
  • q295657451
  • q295657451
  • 2014年08月11日 21:27
  • 436

UvaLive 6440 - Emergency Handling(数据结构)

题目链接 UvaLive 6440 - Emergency Handling 题意
  • madaidao
  • madaidao
  • 2014年08月01日 15:54
  • 664

UVALive 6440 Emergency Handling 【思维好题啊!!! + 优先队列处理】

传送门 // 题意: 给定n个操作, 如果是f表示有一个病人来就诊, a代表医院可以接受一个病人, 选择的规则为首先选严重程度最严重的, 如果相同就想等级高的, 在相同就可以随意选了. 病人的严重程...
  • Anxdada
  • Anxdada
  • 2018年01月13日 19:43
  • 36

uva136(优先队列)

题意: 不能被2,3,5以外的素数整除的数,称为丑数;找出第1500个丑数; 思路: 用优先队列和map判重; 如果x是丑数,则2x,3x,5x都是丑数; 不停的放出优先队列; 并...
  • yeyeyeguoguo
  • yeyeyeguoguo
  • 2015年03月31日 20:20
  • 839

hihocoder # Inventory is Full(记录,优先队列维护)

题目链接:http://hihocoder.com/contest/hihointerview22/problem/1 题意: 有m种财宝,第i种财宝有ai个,只能存放在与其相匹配的栈中,有n个插...
  • Fistice
  • Fistice
  • 2016年11月02日 18:15
  • 210

优先队列的数组实现(有序)

优先队列上文介绍了一种方法,另一种方法就是在insert()方法中添加代码,将所有较大的元素向右边一定一格以使数组保持有序(和插入排序一样)。这样,最大的元素总会在数组的一边,优先队列的删除最大元素操...
  • heifan2014
  • heifan2014
  • 2016年10月10日 20:04
  • 1186

1003. Emergency (25) <优先队列>

As an emergency rescue team leader of a city, you are given a special map of your country. The map s...
  • qq_33193309
  • qq_33193309
  • 2017年06月07日 18:03
  • 103

【PAT 1003】 Emergency 图论Dijkstra

1003. Emergency (25) 时间限制 400 ms 内存限制 32000 kB 代码长度限制 16000 B 判题程序 Standard 作者 ...
  • tiantangrenjian
  • tiantangrenjian
  • 2014年02月18日 22:37
  • 2901

虚拟机RHEL7启动进入emergency mode问题

开启虚拟机后进入该环境: welcome to emergency mode!after logging in ,type “journalctl -xb” to view system log...
  • lowwwwwww
  • lowwwwwww
  • 2017年07月28日 09:20
  • 456
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Uva 6440 - Emergency Handling 多个优先队列维护
举报原因:
原因补充:

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