[noip2016]洛谷2827
来一发文字证明~
数据范围很大。。。
如果用priority_queue搞的话肯定是会t的。
所以肯定要想一想优化的思路。
我们发现,对于队列来讲,同加,减是不改变这个队列的大小关系的;
但是呢,切开蚯蚓以及新蚯蚓不加是会改变这个队列的大小关系的。
一种简单的想法是priority_queue(都说了会t啊喂)。
另一种是把切出来的两条蚯蚓隔离开,发现每次都会切出两种类型的蚯蚓,一种长的和一种短的。(因为是按比例切割)
那么把这两条蚯蚓放到两个队列当中,就能够隔离这两只蚯蚓,从而起到保护主队单调性的作用
问题是要不要用priority_queue。
我们发现,在队列一和队列二当中,相邻的两个元素总是紧接着放进去的(废话吗不是)
问题来了,这两条蚯蚓来自哪里?
答案是原来所有蚯蚓中第一大和第二大的蚯蚓,显然这两条蚯蚓是这两条蚯蚓同一比例的后代
所以前面的蚯蚓就自然大于后面的蚯蚓,因此就删去了priority_queue这个操作。
那么我们可以证明,这样处理的三个队列(主队,长蚯蚓队,短蚯蚓队)都是单调的,也就是队头大于等于该队的所有元素。
最后就是,我们不能每次都加上一个q(显然是找t)我们假装这个蚯蚓在取出的一瞬间长大了(i-1)*q(i为秒数)然后塞回去的时候在减去i*q即可
(注:必须加上(i-1)*q,不然向下取整精度会不准)
上代码~
#include<stdio.h>
#include<queue>
#include<algorithm>
using namespace std;
int n;int m;int q;int u;int v;int t;
queue <int> q1;queue <int> q2;queue <int> q3;
inline int maxnum()//取最大值的操作
{
int res=-0x3f3f3f3f;int num=0;
if(!q1.empty()&&res<q1.front())res=q1.front(),num=1;
if(!q2.empty()&&res<q2.front())res=q2.front(),num=2;
if(!q3.empty()&&res<q3.front())res=q3.front(),num=3;
if(num==1)q1.pop();
else if(num==2)q2.pop();
else if(num==3)q3.pop();
return res;
}
int a[100000];int now;int j;
int main()
{
scanf("%d%d%d%d%d%d",&n,&m,&q,&u,&v,&t);
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
sort(a,a+n);
for(int i=n-1;i>=0;i--)//倒着扫!(敲黑板)sort最大值在最后
{
q1.push(a[i]);
}
for(int i=1;i<=m;i++,j+=q)//据说这样可以减少运算,priority_queue想卡常结果失败。。
{
int te=maxnum()+j;
if(i%t==0)printf("%d ",te);
//printf("ais%d bis%d\n",t*u/v-i*q,t-t*u/v-i*q);
int ma=max(1LL*te*u/v-j-q,te-1LL*te*u/v-j-q);q2.push(ma);//大的放q2,小的放q3
int mi=min(1LL*te*u/v-j-q,te-1LL*te*u/v-j-q);q3.push(mi);
}
printf("\n");
for(int i=1;!q1.empty()||!q2.empty()||!q3.empty();i++)
{
int res=maxnum();
if(i%t==0)printf("%d ",res+j);
}
return 0;
}
[noip2016]洛谷2827的更多相关文章
- 【BZOJ】4721: [Noip2016]蚯蚓 / 【洛谷】P2827 蚯蚓(单调队列)
Description 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳 蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮 ...
- 洛谷 题解 P1600 【天天爱跑步】 (NOIP2016)
必须得说,这是一道难题(尤其对于我这样普及组205分的蒟蒻) 提交结果(NOIP2016 天天爱跑步): OJ名 编号 题目 状态 分数 总时间 内存 代码 / 答案文件 提交者 提交时间 Libre ...
- 洛谷 1600 (NOIp2016) 天天爱跑步——树上差分
题目:https://www.luogu.org/problemnew/show/P1600 看TJ:https://blog.csdn.net/clove_unique/article/detail ...
- 洛谷 2831 (NOIp2016) 愤怒的小鸟——仅+1所以bfs优化
题目:https://www.luogu.org/problemnew/show/P2831 状压dp.跑得很慢.(n^2*2^n) 注意只打一只猪的情况. #include<iostream& ...
- 洛谷 P5527 - [Ynoi2012] NOIP2016 人生巅峰(抽屉原理+bitset 优化背包)
洛谷题面传送门 一道挺有意思的题,想到了某一步就很简单,想不到就很毒瘤( 首先看到这样的设问我们显然可以想到背包,具体来说题目等价于对于每个满足 \(i\in[l,r]\) 的 \(a_i\) 赋上一 ...
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
- 洛谷P1108 低价购买[DP | LIS方案数]
题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...
- 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP
题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...
随机推荐
- Mysql 存储过程查询结果赋值到变量的方法
drop table if exists test_tbl; create table test_tbl (name varchar(20), status int(2)); insert into ...
- Maven中添加镜像
Maven库在天朝的下载速度实在是感人,所以添加镜像之后速度会提升很多. 在maven的settings.xml 文件里配置mirrors的子节点,添加如下mirror <mirror> ...
- PTA --- 时间复杂度 选择题
1-1 2N和NN具有相同的增长速度. (2分) T F 作者: DS课程组 单位: 浙江大学 1-2 (NlogN)/1000是O(N)的. (1分) T ...
- 使用 ado.net访问数据库
一.ADO.NET :用于连接数据库的技术 1.ADO.NET分为两大组件 DataSet:数据集 .NET FRAMWORK :用于连接到数据库,发送命令,检索结果 2.ADO. ...
- L358 World Book Day
World Book Day is celebrated by UNESCO and other related organisations every year on the 23rd of Apr ...
- ansible 变量详解
定义变量的方法 1. 主机变量,在hosts文件中设置变量, [atlanta] host1 http_port= maxRequestsPerChild= host2 http_port= maxR ...
- TSMBIOS
TSMBIOS Object Pascal language (Delphi or Free Pascal). https://github.com/RRUZ/tsmbios
- java 第三周作业
1.P132分析: long before = System.currentTimeMillis(); //返回当前的计算机时间,时间的表达格式为当前计算机时间和GMT时间(格林威治时间)1970年1 ...
- linux查找指定目录文件大小
#遍历查询 /users/yyqh01/ 目录下的文件目录大小,按M打印大小 for i in $(echo /users/yyqh01/*/) ; do [ "$i" != &q ...
- Arm11-mini6410入坑
Mini6410 学习Stm32的时候原子哥的资料真全啊,而且原子哥在他论坛也解答问题.然而现在学习ARM买了一套友善之臂的开发板,官方的资料只能刚好入门而已,其实入门都算不上.看了一下,网上的资料很 ...