codevs 2830 蓬莱山辉夜
2830 蓬莱山辉夜
在幻想乡中,蓬莱山辉夜是月球公主,居住在永远亭上,二次设定说她成天宅在家里玩电脑,亦称NEET姬
一天,她要她帮忙升级月球的网络服务器,应为注册用户过多(月兔和地球上的巫女都注册了……),所以作为代理管理员(俗称网管)的她,非常蛋疼。
注册用户格式:
TouhouMaiden 2004 200
其中前面的Touhoumaiden是预设,不做更改,第一个数是标识,第二个数是每次接受信息访问的间隔用时。
你要做的事,就是给定一群用户及n,求出这n次信息访问中,访问到了谁?
presented by Izayoi sakuya

以题目预设格式输入,另起一行以‘#’结束,在其一行输入n
n行,每行输出第行次后,信息访问到了谁?若在一个时间有若干少女被访问到,输出字典序最小的那位少女的标识
TouhouMaiden 2004 200
TouhouMaiden 2005 300
#
5
2004
2005
2004
2004
2005
标识和每次信息访问间隔均在integer内,n<=10000
原本是要用到堆,但深搜+时间即可搞定
数据有点少但也都够变态了
本题描述有问题。题目中说:“若在一个时间有若干少女被访问到,输出字典序最小的那位少女的标识”,然而样例是按字典序全部输出
本题的意思:许多人排队等待被访问,他们每人都有一个编号(输入数据每一行的第一个数字),和一个时间,时间为等待时间(输入数据每一行的第二个数字)+已花费时间。他们排队的顺序为先按等待时间排序,若等待时间相同再按编号的字典序排序。然而每个人都想多次被访问,所以他们每次被访问完后,都会再去插队,再等待他们相应的等待时间再次被访问,访问完了之后再去插队……他们并不是老老实实的去排队,而是插队,插到等待时间+已花费时间比他还要长的人的前面。(也就是总时间少的人先被访问)
所以可以建立一个小根堆,每次取出堆中的第一个元素,输出编号,加上等待时间再放进堆里去,循环n次。
#include<iostream>
#include<cstdio>
#include<algorithm>
struct node
{
int a,b,c;//a编号,b已花费时间,c等待时间
}e[];
using namespace std;
int n,s,i,l[];//s堆heap中元素的个数,l用于存放时间相同的少女的编号
char c[];
node heap[];//堆
bool cmp(node k,node p)
{
return k.b<p.b;
}
void insert(node k)//向堆中加入元素
{
s++;
heap[s]=k;
int p=s;
while(p>&&k.b<heap[p/].b)
{
heap[p]=heap[p/];
p/=;
}
heap[p]=k;
}
void heapify(int k)//维护小根堆
{
int left=k*,right=k*+;
int minn=k;
if(left<=s) minn=heap[minn].b<heap[left].b ? minn:left;
if(right<=s) minn=heap[minn].b<heap[right].b ? minn:right;
if(minn!=k)
{
swap(heap[minn],heap[k]);
heapify(minn);
}
}
node get()//取出堆中第一个元素
{
node k=heap[];
heap[]=heap[s];
s--;
heapify();
return k;
}
int main()
{
cin>>c;
while(c[]!='#')
{
i++;
scanf("%d%d",&e[i].a,&e[i].b);
e[i].c=e[i].b;
insert(e[i]);
cin>>c;
}
scanf("%d",&n);
while(n)
{
bool ok=false;
node h=get();//取出堆中的第一个元素
int o=h.a;//这次要输出的元素的编号
int su=;//相同时间的少女的个数
while(h.b==heap[].b) //有少女在相同时间被访问到
{
ok=true;
l[++su]=h.a;//存进去
h.b+=h.c;//加上等待时间
insert(h);//再放回堆里
h=get();//再取出堆得第一个元素
o=min(o,h.a);
}
l[++su]=h.a;
h.b+=h.c;
insert(h);
//如过存在几个少女同一时间被访问到的情况,那根据上面的while,最后一个同一时间的少女没有取出来放入l数组,所以要加进去
//如果不存在几个少女同一时间被访问的情况,语句l[++su]=h.a执行没有影响,实际有作用的是后两句
if(ok)
{
sort(l+,l+su+);//按字典序输出
for(int i=;i<=su;i++)
printf("%d\n",l[i]);
n-=su;
continue;
}
printf("%d\n",o);//没有少女在同一时间被访问,直接输出编号
n--;
}
}
codevs 2830 蓬莱山辉夜的更多相关文章
- AC日记——蓬莱山辉夜 codevs 2830
2830 蓬莱山辉夜 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Description 在幻想乡中,蓬莱山辉夜是月球 ...
- codevs2830 蓬莱山辉夜
2830 蓬莱山辉夜 题目描述 Description 在幻想乡中,蓬莱山辉夜是月球公主,居住在永远亭上,二次设定说她成天宅在家里玩电脑,亦称NEET姬一天,她要她帮忙升级月球的网络服务器,应为注 ...
- Codevs堆练习
Codevs堆练习 黄金:2830.2879.2995.3110 钻石:1052.1063.1245.1246.2057.2573.3377 大师:1021.1765.2069.2913.3032
- codevs 3289 花匠
题目:codevs 3289 花匠 链接:http://codevs.cn/problem/3289/ 这道题有点像最长上升序列,但这里不是上升,是最长"波浪"子序列.用动态规划可 ...
- codevs 1082 线段树练习 3(区间维护)
codevs 1082 线段树练习 3 时间限制: 3 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...
- codevs 1285 二叉查找树STL基本用法
C++STL库的set就是一个二叉查找树,并且支持结构体. 在写结构体式的二叉查找树时,需要在结构体里面定义操作符 < ,因为需要比较. set经常会用到迭代器,这里说明一下迭代器:可以类似的把 ...
- codevs 1576 最长上升子序列的线段树优化
题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...
- codevs 1080 线段树点修改
先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...
- codevs 1228 苹果树 树链剖分讲解
题目:codevs 1228 苹果树 链接:http://codevs.cn/problem/1228/ 看了这么多树链剖分的解释,几个小时后总算把树链剖分弄懂了. 树链剖分的功能:快速修改,查询树上 ...
随机推荐
- 由objC运行时所想到的。。。
objC语言不仅仅有着面向对象的特点(封装,继承和多态),也拥有类似脚本语言的灵活(运行时),这让objC有着很多奇特的功能-可在运行时添加给类或对象添加方法,甚至可以添加类方法,甚至可以动态创建类. ...
- jQuery对象和DOM对象的区别
jQuery对象和DOM对象使用说明,需要的朋友可以参考下.1.jQuery对象和DOM对象第一次学习jQuery,经常分辨不清哪些是jQuery对象,哪些是 DOM对象,因此需要重点了解jQuery ...
- 安卓Design包下的TextInputLayout和FloatingActionButton的简单使用
终于介绍到Design包的最后的东西了. 也很简单,一个是TextInputLayout. TextInputLayout作为一个父容器,包含一个新的EditText,可以给EditText添加意想不 ...
- 原创:MD5 32位加密软件
网站后台数据库切勿使用明文保存密码,否则一旦黑客拿下你的Webshell,后果不堪设想. 网站后台密码加密大多数采用的就是MD5算法加密.今天给大家送一个本人用c#简单编写的MD5 32位加密程序,虽 ...
- 『.NET Core CLI工具文档』(一).NET Core 命令行工具(CLI)
说明:本文是个人翻译文章,由于个人水平有限,有不对的地方请大家帮忙更正. 原文:.NET Core Command Line Tools 翻译:.NET Core命令行工具 什么是 .NET Core ...
- WPF 自定义ContextMenu且为左键点击显示
<Button Click="Button_Click_3" Style="{StaticResource NormalButtonStyle}"> ...
- 【无私分享:ASP.NET CORE 项目实战(第二章)】添加EF上下文对象,添加接口、实现类以及无处不在的依赖注入(DI)
目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 上一章,我们介绍了安装和新建控制器.视图,这一章我们来创建个数据模型,并且添加接口和实现类. 添加EF上下文对象 按照我们以前 ...
- C#开发微信门户及应用(15)-微信菜单增加扫一扫、发图片、发地理位置功能
前面介绍了很多篇关于使用C#开发微信门户及应用的文章,基本上把当时微信能做的接口都封装差不多了,微信框架也积累了不少模块和用户,最近发现微信公众平台增加了不少内容,特别是在自定义菜单里面增加了扫一扫. ...
- go-使用 unsafe 修改 struct 中的 field 的值
以下是方法,不要纠结原理,等东西积累多了,你才有能力纠结原理: 首先,你需要有一个这样的函数,这是在 nsq 的源码里直接抄过来的: func unsafeValueOf(val reflect.Va ...
- CSS3之3d变换与关键帧
3d变换是在transform基础上实现的 transform-style:preserve-3d; 建立3d空间 perspective:; 景深(设置用户看的距离) perspective-ori ...