博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
优先队列 HDOJ 5437 Alisha's Party
阅读量:5817 次
发布时间:2019-06-18

本文共 1774 字,大约阅读时间需要 5 分钟。

 

题意:一人过生日,很多人排着队送礼物。排队顺序是礼物价值大的优先,如果相等先来的优先。有m次开门,当t个人到了会开门让p个人进门。最后一次让门外的所有人按顺序进门。有q次询问,问第x个进门的人的名字。

分析:很明显的优先队列,首先交给队友做,结果写的搓,无限RE。没办法只能我上,因为要对字符串处理我用了string,思路正确,各种坑都解决了但是很快WA了,我的内心是奔溃的。赛后发现是cin,cout和scanf,printf冲突了 (ios::sync_with_stdio (false);关闭同步)

,以前听说过这个问题,这次终于碰上了!解题思路是先排好序,t也是要排序的,而且有相同的t,没到t个人来,那么入队t个人,注意队列中不一定有p个人,及时break,详细见代码。

 

代码:

#include 
#include
#include
#include
#include
#include
#include
using namespace std;const int N = 150000 + 10;const int INF = 0x3f3f3f3f;struct People { string name; int v, id; People () {} People (string n, int v, int id) : name (n), v (v), id (id) {} bool operator < (const People &r) const { if (v == r.v) return id > r.id; else return v < r.v; }}p[N], ans[N];struct Op { int t, p; bool operator < (const Op &r) const { if (t == r.t) return p < r.p; else return t < r.t; }}a[N];int main(void) { ios::sync_with_stdio (false);        //用了这句话,puts都不能用了 int T; cin >> T; while (T--) { int n, m, q; cin >> n >> m >> q; for (int i=1; i<=n; ++i) { cin >> p[i].name >> p[i].v; p[i].id = i; } for (int i=1; i<=m; ++i) { cin >> a[i].t >> a[i].p; } sort (a+1, a+1+m); int tot = 0; priority_queue
Q; int n1 = 0, n2 = 1; while (!Q.empty () || n1 <= n) { while (n2 <= m && n1 == a[n2].t) { for (int i=1; i<=a[n2].p; ++i) { if (Q.empty ()) break; ans[++tot].name = Q.top ().name; Q.pop (); } n2++; } n1++; if (n1 > n) break; Q.push (People (p[n1].name, p[n1].v, p[n1].id)); } while (!Q.empty ()) { ans[++tot].name = Q.top ().name; Q.pop (); } for (int x, i=1; i<=q; ++i) { cin >> x; cout << ans[x].name; if (i == q) cout << endl; else cout << " "; } } return 0;}

  

转载于:https://www.cnblogs.com/Running-Time/p/4806322.html

你可能感兴趣的文章
考研太苦逼没坚持下来!看苑老师视频有点上头
查看>>
HCNA——RIP的路由汇总
查看>>
zabbix监控php状态(四)
查看>>
定时任务的创建
查看>>
实战Django:小型CMS Part2
查看>>
原创]windows server 2012 AD架构试验系列 – 16更改DC计算机名
查看>>
统治世界的十大算法
查看>>
linux svn安装和配置
查看>>
SSH中调用另一action的方法(chain,redirect)
查看>>
数据库基础
查看>>
表格排序
查看>>
关于Android四大组件的学习总结
查看>>
java只能的round,ceil,floor方法的使用
查看>>
由于无法创建应用程序域,因此未能执行请求。错误: 0x80070002 系统找不到指定的文件...
查看>>
新开的博客,为自己祝贺一下
查看>>
puppet任务计划
查看>>
【CQOI2011】放棋子
查看>>
采用JXL包进行EXCEL数据写入操作
查看>>
一周总结
查看>>
将txt文件转化为json进行操作
查看>>