【NOIP2016】蚯蚓(队列,单调性)
题解
先来说说非完美解法,也是我去年考场上的做法
考虑一下每一只蚯蚓增加的长度,
这个值并不需要每一次依次增加,
用一个变量维护即可,每次取出蚯蚓就加上这个值,切断蚯蚓就减去这个值。
接下来如何维护最大的蚯蚓,考虑使用一个堆来进行维护
时间复杂度O(mlogm)显然超时(其实也就是常数巨大)
现在,来考虑正解
我们先来脑补几个显然成立的结论
第一个:如果蚯蚓A长于蚯蚓B,一定是优先切蚯蚓A
第二个:一只蚯蚓被切断后,两部分长度一定不会超过原长度
第三个:如果蚯蚓A长于蚯蚓B,若干时间后,A还是长于B(A不被切)
第四个:如果蚯蚓A长于蚯蚓B,A和B切断后,A的两段分别长于B的两段。
那么,我们似乎发现了一点,单调性。
看一看,先切的一定比后切的长。(显然成立呀)
虽然不知道新切出来的部分和下一个切的部分谁更长,但是只需要1次比较就可以知道下一次应该切谁。(比较新切出来的长度和下一个本来应该要切的长度)
那么,我们利用单调性来维护队列。(不需要优先队列了)
首先维护所有初始的蚯蚓长度
然后考虑到所有蚯蚓只会变成两段,并且一段长一段短。那么,再用两个队列维护长的那一段和短的那一段。
现在,得到了3个队列,分别维护初始长度和切下来的两段的长度。
根据上面几个很显然的结论,这三个队列都是满足由长到短的单调性的(初始长度就排个序来维护)
那么,每次取出最长的蚯蚓就只需要考虑三个队列的首元素即可。
这个时候的时间复杂度是O(N+M+NlogN)显然可以在时间范围内求解
这道题目的关键就是 单调性,通过单调性解决掉优先队列,从而优化常数。
最后注意几个小细节:
不要提前算出来P的值,每次用U和V去计算,要不然会掉精度
除的时候一定要强制换成longlong,要不可能会炸int
INF值要开大一点,这样比较的时候才不会出问题。
题目仔细读几遍,看题要仔细。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
using namespace std;
#define MAX 10000100
#define INF 1000000000000000
inline bool cmp(int a,int b)
{
return a>b;
}
long long N,M,Q,U,V,T;
long long q[3][MAX];
long long h[3],t[3];
long long cnt=0,now,fl,aa,bb;
int main()
{
scanf("%d%d%d%d%d%d",&N,&M,&Q,&U,&V,&T);
//P=U/V;
for(int i=1;i<=N;++i)
scanf("%d",&q[0][i]);
sort(&q[0][1],&q[0][N+1],cmp);
h[0]=h[1]=h[2]=1;t[0]=N;t[1]=t[2]=0;
for(int tt=1;tt<=M;++tt)
{
now=fl=-INF;
for(int i=0;i<3;++i)
if(h[i]<=t[i])
if(now<q[i][h[i]])
{
now=q[i][h[i]];
fl=i;
}
h[fl]++;
now+=cnt;
aa=(1LL*now*U)/V;bb=now-aa;
if(aa>bb)swap(aa,bb);
q[1][++t[1]]=bb-cnt-Q;
q[2][++t[2]]=aa-cnt-Q;
cnt+=Q;
if(tt%T==0)
printf("%d ",now);
}
printf("\n");
for(int tt=1;tt<=N+M;++tt)
{
now=fl=-INF;
for(int i=0;i<3;++i)
if(h[i]<=t[i])
if(now<q[i][h[i]])
{
now=q[i][h[i]];
fl=i;
}
if(tt%T==0)
printf("%d ",now+cnt);
h[fl]++;
}
return 0;
}
【NOIP2016】蚯蚓(队列,单调性)的更多相关文章
- [NOIp2016]蚯蚓 (队列)
#\(\color{red}{\mathcal{Description}}\) LInk 这道题是个\(zz\)题 #\(\color{red}{\mathcal{Solution}}\) 我们考虑如 ...
- [Noip2016]蚯蚓 D2 T2 队列
[Noip2016]蚯蚓 D2 T2 Description 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳 蚤国的跳蚤也拿蚯 ...
- 【BZOJ】4721: [Noip2016]蚯蚓 / 【洛谷】P2827 蚯蚓(单调队列)
Description 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳 蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮 ...
- NC16430 [NOIP2016]蚯蚓
NC16430 [NOIP2016]蚯蚓 题目 题目描述 本题中,我们将用符号 \(\lfloor c \rfloor\) 表示对 c 向下取整,例如:\(\lfloor 3.0 \rfloor = ...
- 【noip2016】蚯蚓(单调性+队列)
题目贼长 大意是你有n个线段,每一秒你要拿出来最长的一个线段切成两段长度为[p*u](向下取整)和u-[p*u]两段(其中u是线段长,p是一个大于0小于1的实数)没被切的线段长度加q(0<q&l ...
- [Noip2016]蚯蚓 (单调队列)
题干 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓.蛐蛐国 ...
- 2018.09.11 bzoj47214721: [Noip2016]蚯蚓(单调队列)
传送门 好题. 目测只会多带一个log2(n+m)" role="presentation" style="position: relative;"& ...
- 蚯蚓(noip2016,贪心,单调性)
题目描述 本题中,我们将用符号⌊c⌋ 表示对 c 向下取整,例如:⌊3.0⌋=⌊3.1⌋=⌊3.9⌋=3 . 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭 ...
- 【noip2017 day2T2】【蚯蚓】巧用队列单调性线性处理
(画师当然是武内崇啦) Description 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐 ...
- [noip2016]蚯蚓<单调队列+模拟>
题目链接:https://vijos.org/p/2007 题目链接:https://www.luogu.org/problem/show?pid=2827#sub 说实话当两个网站给出AC后,我很感 ...
随机推荐
- a元素的两个重要功能和表格布局
⦁ 发送邮件:<a href="mailto:231455557@qq.com">联系我们</a> ⦁ 锚点两个重要应用:查看目录 提供菜单功能回到顶 ...
- js收藏代码
js收藏代码~ 1. oncontextmenu="window.event.returnValue=false" 将彻底屏蔽鼠标右键 <table border oncon ...
- Python之数据类型转换
平时我们在处理数据的时候,有些数据类型不是我们想要的,怎么办? 一.数据类型转换:要转换的类型(数据) 要把num01转换为整数:int(num01) 要把num01转换为浮点数:float(num0 ...
- Spring_Spring与AOP_AspectJ基于注解的AOP实现
一.AspectJ.Spring与AOP的关系 AspectJ是一个面向切面的框架,它扩展了Java语言.AspectJ定义了AOP语法,所以它有一个专门的编译器用来生成遵守Java字节编码规范的Cl ...
- PS如何批量生成缩略图(方法可以通用其他重复劳动)
原图 缩略 进入正题,学生时代玩过脚本精灵的应该一点就通 原理就是:录制一系列动作,然后生成脚本,并执行(经常PS水印代码的一个可以用程序实现,一个就可以用PS脚本) 新建一个组 新建一个动作 进行你 ...
- MySQL数据库基础(一)(启动/停止、登录/退出、语法规范及最基础操作)
1.启动/停止MySQL服务 启动:net start mysql 停止:net stop mysql 2.MySQL登录/退出 登录:mysql 参数:如果连接的是本地服务器,一般用命令:my ...
- vim+makefile入门编辑,编译,差错实例
vim+makefile入门编辑,编译,差错实例 vim makefile 编译 编写代码,一般在vim中编辑完后,输入:wq,在命令行下输入g++ hello.cc -o hello ,出现问题,打 ...
- centos/linux下的安装Nginx
1.安装gcc编译器 先查看gcc编译器是否安装 在shell控制台输入gcc-v 如果没有安装请看下一步 使用yuma安装gcc yum intsall gcc 看到如下视图则说明安装成功 2.安装 ...
- Sping Boot入门到实战之入门篇(一):Spring Boot简介
该篇为Spring Boot入门到实战系列入门篇的第一篇.对Spring Boot做一个大致的介绍. 传统的基于Spring的Java Web应用,需要配置web.xml, applicationCo ...
- iOS程序闪退的原因以及处理办法
iOS程序闪退是一种比较常见的现象.闪退的情况很多,造成程序闪退的原因也很多. ================================启动时闪退======================= ...