HDU OJ 5437 Alisha’s Party 2015online A
题目:click here
题意:
邀请k个朋友,每个朋友带有礼物价值不一,m次开门,每次开门让一定人数p(如果门外人数少于p,全都进去)进来,当最后所有人都到了还会再开一次门,让还没进来的人进来,每次都是礼物价值高的人先进。最后给出q个数,表示要输出第ni个进来的人的名字。
分析:
优先队列问题。注意优先队列的比较函数即出队顺序,
#include <iostream>
#include <cstdio>
#include <queue>
#include <cstring>
#include <algorithm> using namespace std;
const int M = ; struct Node { // 保存来客信息
char name[];
int val;
int id;
bool operator < ( const Node x ) const { // 排序注意--在优先队列中的出队顺序
if( val == x.val ) return id > x.id;
return val < x.val;
}
}node[M];
struct Time { // 保存开门信息--要排序--给的数据可能不按顺序
int t, p;
bool operator < ( const Time x ) const { return t < x.t; }
}time[M]; int k, m, q;
char str[M][]; // 答案 void solve() {
scanf("%d%d%d", &k, &m, &q );
for( int i=; i<=k; i++ ) {
scanf("%s %d", node[i].name, &node[i].val );
node[i].id = i;
}
for( int i=; i<m; i++ )
scanf("%d%d", &time[i].t, &time[i].p );
sort( time, time+m ); // 对开门信息排序
priority_queue<Node> Q;
int order = ;
int last = ;
for( int i=; i<m; i++ ) {
int t, p; t = time[i].t; p = time[i].p;
for( int i=last+; i<=t; i++ ) {
Q.push( node[i] );
}
for( int i=; i<p; i++ ) {
if( Q.empty() ) break; // 注意当门外的人数比p小时--队列判空直接结束--否则会RE
Node nd = Q.top(); Q.pop();
order++;
strcpy( str[order], nd.name );
}
last = t;
}
for( int i=last+; i<=k; i++ ) // m次开门后还要开门一次--门外所有人都进门
Q.push( node[i] );
while( !Q.empty() ) {
Node nd = Q.top(); Q.pop();
order++;
strcpy( str[order], nd.name );
}
bool fo = false; // 输出格式
for( int i=; i<=q; i++ ) {
int s; scanf("%d", &s );
if( fo ) printf(" %s", str[s] );
else { printf("%s", str[s] ); fo = true; }
}
printf("\n");
} int main() {
int t; scanf("%d", &t );
while( t-- ) {
solve();
}
return ;
}
HDU OJ 5437 Alisha’s Party 2015online A的更多相关文章
- [C#] 逆袭——自制日刷千题的AC自动机攻克HDU OJ
		
前言 做过杭电.浙大或是北大等ACM题库的人一定对“刷题”不陌生,以杭电OJ为例:首先打开首页(http://acm.hdu.edu.cn/),然后登陆,接着找到“Online Exercise”下的 ...
 - hdu oj 1285 确定比赛名次
		
hdu oj 1285 确定比赛名次 题目: 确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K ...
 - sort(hdu oj 1425)计数排序和快速排序
		
Description 给你n个整数,请按从大到小的顺序输出其中前m大的数. Input 每组测试数据有两行,第一行有两个数n,m(0 < n,m < 1000000),第二行包含n个各不 ...
 - hdu 5437 Alisha’s Party 优先队列
		
Alisha’s Party Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/contests/contest_sh ...
 - hdu 5437 Alisha’s Party  模拟 优先队列
		
Problem Description Princess Alisha invites her friends to come to her birthday party. Each of her f ...
 - HDU 5437 Alisha’s Party  (优先队列)——2015 ACM/ICPC Asia Regional Changchun Online
		
Problem Description Princess Alisha invites her friends to come to her birthday party. Each of her f ...
 - 优先队列 + 模拟 - HDU 5437 Alisha’s Party
		
Alisha’s Party Problem's Link Mean: Alisha过生日,有k个朋友来参加聚会,由于空间有限,Alisha每次开门只能让p个人进来,而且带的礼物价值越高就越先进入. ...
 - HDU 5437 Alisha’s Party (优先队列模拟)
		
题意:邀请k个朋友,每个朋友带有礼物价值不一,m次开门,每次开门让一定人数p(如果门外人数少于p,全都进去)进来,当最后所有人都到了还会再开一次门,让还没进来的人进来,每次都是礼物价值高的人先进.最后 ...
 - HDU 5437  Alisha’s Party
		
题意:有k个人带着价值vi的礼物来,开m次门,每次在有t个人来的时候开门放进来p个人,所有人都来了之后再开一次门把剩下的人都放进来,每次带礼物价值高的人先进,价值相同先来先进,q次询问,询问第n个进来 ...
 
随机推荐
- BZOJ 1179 [Apio2009]Atm(强连通分量)
			
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1179 [题目大意] 给出一张有向带环点权图,给出一些终点,在路径中同一个点的点权只能累 ...
 - poj1862---变形虫(贪心)
			
题意:两条虫之间碰在一起,质量变为2*sqrt(m1*m2) 求怎么结合,能使最后的一只虫质量最小 分析:如果让按从大到小的顺序依次结合,可以使大的数被开方的次数最多,得到的结果更小 4 3 2 1 ...
 - SQL Server 2008 批量插入数据时报错
			
前几天在SQL Server 2008同步产品数据时,总是提示二进制文本被截断的错误,但是经过检查发现数据都符合格式要求. 百思不得其解,单独插入一条条数据则可以插入,但是批量导入则报错. 批量导入代 ...
 - (function(){}())写法的用途
			
全局命名空间污染与 IIFE 总是将代码包裹成一个 IIFE(Immediately-Invoked Function Expression),用以创建独立隔绝的定义域.这一举措可防止全局命名空间被污 ...
 - pl/sql developer 编码格式设置(转)
			
一.pl/sql developer 中文字段显示乱码 原因:因为数据库的编号格式和pl /sql developer的编码格式不统一造成的. 二.查看和修改oracle数据库字符集: select ...
 - Javascript  基础编程练习一
			
Javascript 基础互动编程,这篇练习结合了function 函数名(), onclick 时间, prompt输入窗口, window.open和confirm窗口, 任务 1.新窗口打开时弹 ...
 - matlab最小二乘法数据拟合函数详解
			
定义: 最小二乘法(又称最小平方法)是一种数学优化技术.它通过最小化误差的平方和寻找数据的最佳函数匹配.利用最小二乘法可 以简便地求得未知的数据,并使得这些求得的数据与实际数据之间误差的平方和为最小. ...
 - SQL SERVER2012新分页方式  轉載
			
SQL SERVER2012在ORDER BY 子句中加入了新元素offset,允许用户在排序完成的结果集中自定义输出行范围,大大简化了分页SQL的书写方式和效率. SQL SERVER2012在OR ...
 - ios不同版本下的UILabel自动换行问题
			
@interface ThreadPreviewCell : UITableViewCell @property (nonatomic, strong) UILabel *titleLabel; @e ...
 - 红豆带你从零学C#系列之:开始C#编程(一)
			
让我们开始学习C#编程吧 作者:红豆西米露 交流QQ:937802080 前面的文章里给大家介绍了C#语言的一些基本认识,现在我们来开始做一个小程序吧! 在这里以我们以“控制台应用程序”来作演示. P ...