[noip2016]蚯蚓<单调队列+模拟>
题目链接:https://vijos.org/p/2007
题目链接:https://www.luogu.org/problem/show?pid=2827#sub
说实话当两个网站给出AC后,我很感动。。。。这题啊,思路容易想到,就是小细节太烦了。。。。。
【思路】
这道题要开三个队列,而且需要证明到一个点才能够做。。
就是先切的蚯蚓的部分,比后切的蚯蚓的对应部分长。。。有可能你会想蚯蚓不是随时在长吗,当然这不影响。。我们来简单证明一下
------------------------------------------------证明部分-------------------------------------------------------
首先第一存初始的蚯蚓,x1>x2,先切x1,切完是x1*p(A部分)和x1-x1*p(B部分),另外一个变长成为x2+q;
第二个时间点切原来x2这条,切完是(x2+q)*p(A部分)和x2+q-(x2+q)*p(B部分),第一条蚯蚓切后长成x1*p+q和x1-x1*p+q
然后来对应比较 我们以A部分为例子 x1*p+q : (x2+q)*p=x2*p+q*p
由题意可以知道p的范围是0<p<1,所以x1*p>x2*p,q>q*p进一步得出所以 x1*p+q> (x2+q)*p,同理,切出来的另一半也是这样的。。
-----------------------------------------------------------------------------------------------------------------
所以我们只要不断的将新切出来的蚯蚓按A部分和B部分分别压入两个队列,那这两个队列都是单调队列
每次选择要切的蚯蚓只需要取这三个队列队首的最大值
第二个要考虑的问题就是蚯蚓长大的问题,为了更好的处理这个细节,我们对每一个蚯蚓对还原成最初状态,即在变长后切割完就减去当前的时间*q。。
减去以后,三个队列里的蚯蚓都是没有成长的状态,有可能有负数但是不影响。。。
【细节问题】
1.首先是数组范围,队列我没试过,但是我数组开10^6是runtime error了。后来开成10^7才通过
2.接着是用来找最大值的ans,就是用来更新并求最大值的一个变量(详细见代码),这个东东的初值要是10^9以上的,虽然题目说蚯蚓长小于10^8,但是在m秒后长大了
m*q的长度,这加起来就接近10^8次方了,所以这也是一个细节
3.还有就是把蚯蚓减回初识形态时,不仅要减去之前时间大家长大的长度,还要额外减去一个,因为被砍的蚯蚓当前这一秒是不会生长,相对于所有就要少一个q,为了保证最后所有的蚯蚓+m*q就是正确值,就要对当前切开的蚯蚓额外减去q
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<cmath>
#include<queue>
#define maxn 100005
#define maxm 700005
#define maxv 10000005
#define inf 2000000005
using namespace std; int h[],t[],a[maxm];//h->指针,队首......t->队的长度
int b[][maxv],n,m,q,u,v,tt,del; int comp(const void*a,const void*b){
return (*(int*)a)<(*(int*)b)?:-;
} int main(){
scanf("%d%d%d%d%d%d",&n,&m,&q,&u,&v,&tt);
h[]=h[]=h[]=;
for(int i=;i<=n;i++)scanf("%d",&a[i]);
a[]=inf;
qsort(a,n+,sizeof(int),comp);
for(int i=;i<=n;i++)b[][i]=a[i];
t[]=n; for(int i=;i<=m;i++){
int ans=-inf,num=;//num表示当前选出队首最大的那个队列序号
for(int j=;j<=;j++){
if(h[j]<=t[j]){//指针不越界
if(b[j][h[j]]>ans){
ans=b[j][h[j]];num=j;//找三个队列的队首最大值
}
}
}
if(i%tt==)printf("%d ",ans+del);
h[num]++;//理解为删除操作
b[][++t[]]=(long long)(ans+del)*u/v-del-q;//队尾压入一个切开的A值
b[][++t[]]=ans+del-(long long)(ans+del)*u/v -del-q;//队尾压入一个切开的B值
del+=q;
}
printf("\n");
for(int i=;i<=n+m;i++){
int ans=-inf,num=;
for(int j=;j<=;j++){
if(h[j]<=t[j]&&b[j][h[j]]>ans){
ans=b[j][h[j]];num=j;
}
}
if(i%tt==){ printf("%d ",ans+del);}
h[num]++;
}
return ;
}
【总结】
1.对于一道题,要分析数据的变化,就像这题中蚯蚓的长度一样,不是始终小于题所给的10^8,所以要分析全局来赋值
2.数组的大小要严谨分析,在不会爆内存的情况下可以多开,虽然我刚刚开始开的是n+m大小,但是因为不会删去之前的蚯蚓,所以这个大小还不够,还是会越界
3.很多题是带有结论的,需要去证明,所以不要盲目去做一题,稍加分析,当然也可以先打暴力来辅助分析
[noip2016]蚯蚓<单调队列+模拟>的更多相关文章
- [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 = ...
- 【bzoj4721】[Noip2016]蚯蚓
题目描述 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓.蛐 ...
- 【uoj264】 NOIP2016—蚯蚓
http://uoj.ac/problem/264 (题目链接) 题意 n条蚯蚓,时间为m.每单位时间要可以将最长的蚯蚓切成len/2和len-len/2两份,长度为0的蚯蚓不会消失,因为每单位时间所 ...
- BZOJ4721 [Noip2016]蚯蚓
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- [NOIp2016] 蚯蚓
类型:单调队列 传送门:>Here< 题意:有$N$只蚯蚓,每秒都会伸长$q$.每一次都会有人选出最长的一条切成两半,长度分别是$\left \lfloor px \right \rflo ...
- luogu2827 [NOIp2016]蚯蚓 (模拟)
可以直观地想到用优先队列来做,但数据范围是O(n)的 然后我们发现,因为我们每次挑出来的蚯蚓是单调的,所以把每个切成两段后,那两段也是对应单调的 也就是说,算上最一开始的蚯蚓,我们一共维护三个队列,三 ...
- [NOIp2016]蚯蚓 (队列)
#\(\color{red}{\mathcal{Description}}\) LInk 这道题是个\(zz\)题 #\(\color{red}{\mathcal{Solution}}\) 我们考虑如 ...
- 【bzoj4721】[Noip2016]蚯蚓 乱搞
题目描述 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓.蛐 ...
随机推荐
- beego的安装以及bee的安装和使用
beego的安装以及bee的安装和使用 一.beego的安装 1.beego是什么 beego 是一个快速开发 Go 应用的 HTTP 框架,他可以用来快速开发 API.Web 及后端服务等各种应用, ...
- An incompatible version [1.1.33] of the APR based Apache Tomcat Native library is installed, while Tomcat requires version [1.2.14]
Springboot项目启动出现如下错误信息 解决办法在此地址:http://archive.apache.org/dist/tomcat/tomcat-connectors/native/1.2.1 ...
- golang 交叉编译 win开发 linux生产
windows平台之下使用 go env 能看到go本身的配置的环境变量,其中红框框起来的变量是交叉编译需要改动的选项, 由于是win平台开发,但是跑起来的程序都是在linux,所以linux转win ...
- 大数据学习之scala-环境搭建
scala 下载网站 https://www.scala-lang.org/download/ 安装scala要先安装java,并且配置java环境,官网也有说明 不过国内的网站下载不下来可以访问: ...
- c++第二周阶段小测2
函数参数已完成(全部是正确答案) 1 [单选题] 以下关于函数参数的说法,不正确的是 A. 函数调用时,先将实参的值按照位置传递给对应的形参. B. 实参与形参的个数及顺序不必一一对应. ...
- R中character和factor的as.integer的不同
记录一个容易犯错的地方. 用chr标记的0~1变量可以变为整数0和1, 而用因子factor标记的变量转换为整数时总是从1开始. 如果不注意区分就会发生令自己困惑的错误.
- C语言实现简单计算器小项目
昨天刚安装上devc++,半夜想着练练C语言吧 于是就看到实验楼有一个计算器的项目 之前做过一次,这次写的主要是思路 首先我们先从原理思考jia,实现简单的计算器就要具备加减乘除这些,看普通的计算器也 ...
- 用 SendGrid 发送免费电子邮件
1. 概述 SendGrid 免费账号可以限额发送 100/天封邮件,虽然比 Mailgun 的每月 10000 封的免费额度少,但胜成注册无需绑定信息卡. 集成 SendGrid 有 SMTP 和 ...
- watch 同步表单 记得$nextTick,否则不会同步更新到组件内
watch 同步表单 记得$nextTick,否则不会同步更新到组件内 watch: { 'formData.aaa' (val) { this.$nextTick(() => { this.f ...
- Flask wtforms 表单验证使用
目录 wtforms 使用1(简单版): 使用2(复杂版): wtforms 安装:pip3 install wtforms 使用1(简单版): from flask import Flask, re ...