洛谷——P2827 蚯蚓
P2827 蚯蚓
题目描述
本题中,我们将用符号 \lfloor c \rfloor⌊c⌋ 表示对 cc 向下取整,例如:\lfloor 3.0 \rfloor = \lfloor 3.1 \rfloor = \lfloor 3.9 \rfloor = 3⌊3.0⌋=⌊3.1⌋=⌊3.9⌋=3。
蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓。
蛐蛐国里现在共有 nn 只蚯蚓(nn 为正整数)。每只蚯蚓拥有长度,我们设第 ii 只蚯蚓的长度为 a_iai (i=1,2,\dots,ni=1,2,…,n),并保证所有的长度都是非负整数(即:可能存在长度为 00 的蚯蚓)。
每一秒,神刀手会在所有的蚯蚓中,准确地找到最长的那一只(如有多个则任选一个)将其切成两半。神刀手切开蚯蚓的位置由常数 pp(是满足 0 < p < 10<p<1 的有理数)决定,设这只蚯蚓长度为 xx,神刀手会将其切成两只长度分别为 \lfloor px \rfloor⌊px⌋ 和 x - \lfloor px \rfloorx−⌊px⌋ 的蚯蚓。特殊地,如果这两个数的其中一个等于 00,则这个长度为 00 的蚯蚓也会被保留。此外,除了刚刚产生的两只新蚯蚓,其余蚯蚓的长度都会增加 qq(是一个非负整常数)。
蛐蛐国王知道这样不是长久之计,因为蚯蚓不仅会越来越多,还会越来越长。蛐蛐国王决定求助于一位有着洪荒之力的神秘人物,但是救兵还需要 mm 秒才能到来……(mm 为非负整数)
蛐蛐国王希望知道这 mm 秒内的战况。具体来说,他希望知道:
- mm 秒内,每一秒被切断的蚯蚓被切断前的长度(有 mm 个数);
- mm 秒后,所有蚯蚓的长度(有 n + mn+m 个数)。
蛐蛐国王当然知道怎么做啦!但是他想考考你……
不论是手写堆还是STL的优先队列,你都逃不过TLE的好成绩。
// luogu-judger-enable-o2
#include<bits/stdc++.h> #define N 51000110
using namespace std; int n,m,q,u,v,t,size,fq,heap[N];
double p;
//priority_queue<int,vector<int> >Q; struct node{
void push(int x){
int now,next;
heap[++size]=x;
now=size;
while(now>){
next=now>>;
if(heap[next]>=heap[now]) break;
swap(heap[next],heap[now]);
now=next;
}
}
int top(){
int now=,next,ans;
ans=heap[];
heap[]=heap[size--];
while(now*<=size){
next=now*;
if(next<size&&heap[next+]>heap[next]) next++;
if(heap[now]>heap[next]) break;
swap(heap[now],heap[next]);
now=next;
}return ans;
}
}Q; int main() {
scanf("%d%d%d%d%d%d",&n,&m,&q,&u,&v,&t);
p=(double)u/v;
for(int x,i=; i<=n; i++) {
scanf("%d",&x);
Q.push(x);
}
for(int i=; i<=m; i++) {
int top=Q.top();
top+=fq;
if(i%t==) printf("%d ",top);
int a=top*p,b=top-a;
fq+=q;
a-=fq,b-=fq;
Q.push(a);
Q.push(b);
}
// printf("%d\n",size);
puts("");
for(int i=;i<=n+m;i++){
int an=Q.top();
an+=fq;
if(i%t==) printf("%d ",an);
}
return ;
}
仔细观察一下,你就会发现隐含的单调性,假设先被切掉的为$x$,后被切掉的为$y$,那么$x$分成的$x1=px+q$,$x2=x-px+q$,$y$分成的$y1=p*(y+q)$,$y2=y-p*(y+q)$
$x1>=y1$ ,$x2>=y2$
那么本身分成的这两堆就具有一定的单调性
即:$x1>y1>z1>...$,$x2>y2>z2>...$
那么就可以模拟了,每次取三个堆中的最大值即可
#include<iostream>
#include<cstdio>
#include<algorithm> #define N 14010100
using namespace std; int n,m,q,u,v,t,Q[][N];
double p; bool cmp(int x,int y){
return x>y;
} int main() {
// freopen("2827.in","r",stdin);
// freopen("2827.out","w",stdout);
scanf("%d%d%d%d%d%d",&n,&m,&q,&u,&v,&t);
p=(double)u/v; for(int i=;i<=n+;i++) Q[][i]=Q[][i]=Q[][i]=-0x7fffffff; for(int i=; i<=n; i++) scanf("%d",&Q[][i]);
sort(Q[]+,Q[]++n,cmp); int top_1,top_2,top_3,fq=,tail_2,tail_3;
top_1=top_2=top_3=;
tail_2=tail_3=; for(int i=; i<=m; i++) {
int top=-0x7fffffff;
if(top_1<=n) top=max(Q[][top_1],top);
if(top_2<=tail_2) top=max(Q[][top_2],top);
if(top_3<=tail_3) top=max(Q[][top_3],top); if(top==Q[][top_1]&&top_1<=n) top_1++;
else if(top==Q[][top_2]&&top_2<=tail_2) top_2++;
else top_3++; top+=fq;
if(i%t==) printf("%d ",top);
int a=top*p,b=top-a;
fq+=q;
a-=fq,b-=fq;
Q[][++tail_2]=b;
Q[][++tail_3]=a;
}
puts(""); for(int i=;i<=n+m;i++){
int top=-0x7fffffff;
if(top_1<=n) top=max(Q[][top_1],top);
if(top_2<=tail_2) top=max(Q[][top_2],top);
if(top_3<=tail_3) top=max(Q[][top_3],top); if(top==Q[][top_1]&&top_1<=n) top_1++;
else if(top==Q[][top_2]&&top_2<=tail_2) top_2++;
else top_3++; if(i%t==) printf("%d ",top+fq);
} return ;
}
洛谷——P2827 蚯蚓的更多相关文章
- 洛谷P2827 蚯蚓 题解
洛谷P2827 蚯蚓 题解 题目描述 本题中,我们将用符号 ⌊c⌋ 表示对 c 向下取整. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓. 蛐蛐国里现 ...
- NOIP 2016 洛谷 P2827 蚯蚓 题解
题目传送门 展开 题目描述 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳 蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手 ...
- 洛谷 P2827 蚯蚓 解题报告
P2827 蚯蚓 题目描述 本题中,我们将用符号 \(\lfloor c \rfloor\) 表示对 \(c\) 向下取整,例如:\(\lfloor 3.0 \rfloor = \lfloor 3.1 ...
- 洛谷P2827 蚯蚓——思路题
题目:https://www.luogu.org/problemnew/show/P2827 思路... 用优先队列模拟做的话,时间主要消耗在每次的排序上: 能不能不要每次排序呢? 关注先后被砍的两条 ...
- 洛谷 P2827 蚯蚓
题目描述 本题中,我们将用符号\lfloor c \rfloor⌊c⌋表示对c向下取整,例如:\lfloor 3.0 \rfloor= \lfloor 3.1 \rfloor=\lfloor 3.9 ...
- 洛谷P2827 蚯蚓(单调队列)
题意 初始时有$n$个蚯蚓,每个长度为$a[i]$ 有$m$个时间,每个时间点找出长度最大的蚯蚓,把它切成两段,分别为$a[i] * p$和$a[i] - a[i] * p$,除这两段外其他的长度都加 ...
- 洛谷p2827蚯蚓题解
题目 算法标签里的算法什么的都不会啊 什么二叉堆?? qbxt出去学习的时候讲的,一段时间之前做的,现在才写到博客上的 维护3个队列,队列1表示最开始的蚯蚓,队列2表示每一次被切的蚯蚓被分开的较长的那 ...
- 洛谷 P2827 蚯蚓 题解
每日一题 day32 打卡 Analysis 我们可以想一下,对于每一秒除了被切的哪一个所有的蚯蚓都增长Q米,我们来维护3个队列,队列1表示最开始的蚯蚓,队列2表示每一次被切的蚯蚓被分开的较长的那一部 ...
- 洛谷P2827蚯蚓
题目 堆+模拟,还有一个小优化(优化后跟堆关系不大,而是类似于贪心). 如果不加优化的话,卡常可以卡到85. 思路是对于对每一秒进行模拟,用堆来维护动态的最大值,然后对于每个长度都加q的情况可以用一个 ...
随机推荐
- web前端和后端的区别
一句话,展示ui相关的就是前端,否则就是后端. 前端语言:javascript.css和html. 后端就是一些服务.
- Vijos 1565 多边形 【区间DP】
描述 zgx给了你一个n边的多边形,这个多边形每个顶点赋予一个值,每条边都被标上运算符号+或*,对于这个多边形有一个游戏,游戏的步骤如下:(1)第一步,删掉一条边:(2)接下来n-1步,每步对剩下的边 ...
- python 矩阵
python的numpy库提供矩阵运算的功能,因此我们在需要矩阵运算的时候,需要导入numpy的包. 1.numpy的导入和使用 from numpy import *;#导入numpy的库函数 im ...
- html鼠标事件
jsp鼠标事件汇总 onclick 单击时触发的事件,这个比较常用 ondblclick 双击时触发的事件 onmoucedown 鼠标按下时触发的事件(个人觉得与onclick异曲同工) onmou ...
- eclipse导出签名apk的混淆设置
1.设置project.properties文件: 2.设置proguard-project.txt文件:
- django 数据库连接模块解析及简单长连接改造
django 数据库连接模块解析及简单长连接改造工作中纯服务端的项目用到了线程池和django的ORM部分.django 的数据库连接在每一个线程中开启一份,并在查询完毕后自动关闭连接. 线程池处理任 ...
- Ural 1517. Freedom of Choice 后缀数组
Ural1517 所谓后缀数组, 实际上准确的说,应该是排序后缀数组. 一个长度为N的字符串,显然有N个后缀,将他们放入一个数组中并按字典序排序就是后缀数组的任务. 这个数组有很好的性质,使得我们运行 ...
- bzoj1050
最小生成树 其实这道题是最小生成树的变种,我们发现答案不一定在最小/最大生成树上,最短路算法也不可行,因为我们我们并不是希望最小值尽量的大,最大值尽量的小,这样不一定是最优的,那么我们枚举最小的边,然 ...
- 使用JS准确获取URL网址中参数的几种方法
记录下使用JS准确获取URL网址中参数的方法: 参考链接1. https://blog.csdn.net/Zhihua_W/article/details/54845945?utm_source=bl ...
- Ruby检验变量
更新: 2017/06/12 更新: 2017/06/16 补充.class的输出 更新: 2017/06/23 .include?检验数组/哈希表是否包含目标值 更新: 2017/07/02 b ...