洛谷 P2827 蚯蚓 解题报告
P2827 蚯蚓
题目描述
本题中,我们将用符号 \(\lfloor c \rfloor\) 表示对 \(c\) 向下取整,例如:\(\lfloor 3.0 \rfloor = \lfloor 3.1 \rfloor = \lfloor 3.9 \rfloor = 3\)。
蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓。
蛐蛐国里现在共有 \(n\) 只蚯蚓(\(n\) 为正整数)。每只蚯蚓拥有长度,我们设第 \(i\) 只蚯蚓的长度为 \(a_i\)(\(i=1,2,\dots,n\)),并保证所有的长度都是非负整数(即:可能存在长度为 \(0\) 的蚯蚓)。
每一秒,神刀手会在所有的蚯蚓中,准确地找到最长的那一只(如有多个则任选一个)将其切成两半。神刀手切开蚯蚓的位置由常数 \(p\)(是满足 \(0 < p < 1\) 的有理数)决定,设这只蚯蚓长度为 \(x\),神刀手会将其切成两只长度分别为 \(\lfloor px \rfloor\) 和 \(x - \lfloor px \rfloor\) 的蚯蚓。特殊地,如果这两个数的其中一个等于 \(0\),则这个长度为 \(0\) 的蚯蚓也会被保留。此外,除了刚刚产生的两只新蚯蚓,其余蚯蚓的长度都会增加 \(q\)(是一个非负整常数)。
蛐蛐国王知道这样不是长久之计,因为蚯蚓不仅会越来越多,还会越来越长。蛐蛐国王决定求助于一位有着洪荒之力的神秘人物,但是救兵还需要 \(m\) 秒才能到来……(\(m\) 为非负整数)
蛐蛐国王希望知道这 \(m\) 秒内的战况。具体来说,他希望知道:
\(m\) 秒内,每一秒被切断的蚯蚓被切断前的长度(有 \(m\) 个数);
\(m\) 秒后,所有蚯蚓的长度(有 \(n + m\) 个数)。
蛐蛐国王当然知道怎么做啦!但是他想考考你……
输入输出格式
输入格式:
第一行包含六个整数 \(n,m,q,u,v,t\),其中:\(n,m,q\) 的意义见【问题描述】;\(u,v,t\) 均为正整数;你需要自己计算 \(p=u / v\)(保证 \(0 < u < v\));\(t\) 是输出参数,其含义将会在【输出格式】中解释。
第二行包含 nn 个非负整数,为 \(a_1, a_2, \dots, a_n\),即初始时 \(n\) 只蚯蚓的长度。
同一行中相邻的两个数之间,恰好用一个空格隔开。
保证 \(1 \leq n \leq 10^5\),\(0 \leq m \leq 7 \times 10^6\),\(0 < u < v \leq 10^9\),\(0 \leq q \leq 200\),\(1 \leq t \leq 71\),\(0 \leq a_i \leq 10^8\)。
输出格式:
第一行输出 \(\left \lfloor \frac{m}{t} \right \rfloor\)个整数,按时间顺序,依次输出第 \(t\) 秒,第 \(2t\) 秒,第 \(3t\) 秒,……被切断蚯蚓(在被切断前)的长度。
第二行输出 \(\left \lfloor \frac{n+m}{t} \right \rfloor\)个整数,输出 \(m\) 秒后蚯蚓的长度;需要按从大到小的顺序,依次输出排名第 \(t\),第 \(2t\),第 \(3t\),……的长度。
同一行中相邻的两个数之间,恰好用一个空格隔开。即使某一行没有任何数需要输出,你也应输出一个空行。
请阅读样例来更好地理解这个格式。
说明:
堆的做法很显然,大概有65~80pts,算是送了很多分了
一看输出都强行怕你T,那一定是\(O(n)\)了
记得合并果子有一个双队列\(O(n)\)做法吗?
事实上跟这个题差不多哒
我们开三个队列,一个存放原来的蚯蚓,一个存放被这样切\(\lfloor px \rfloor\)的蚯蚓,另一个存放被\(x - \lfloor px \rfloorx\)这样切的
注意到在后两个队列中先拿出来的一定比后拿出来的要长,具有单调性
对于第一个队列我们可以先排序,然后每次取三个队列中队尾最大的,切开放到相应的队头
增加的量我们可以维护一个被切断的时间点
注意中间过程可能会爆int
Code:
#include <cstdio>
#include <algorithm>
#define ll long long
const int N=8e6;
ll q1[N][2],q2[N][2],q3[N][2],l1=1,l2=1,l3=1,r1,r2,r3;
ll n,m,q,u,v,t,a[N];//n个m刀增q p=u/v t输出
int main()
{
scanf("%lld%lld%lld%lld%lld%lld",&n,&m,&q,&u,&v,&t);
for(int i=1;i<=n;++i)
scanf("%lld",a+i);
r1=n;
std::sort(a+1,a+1+n);
for(int i=1;i<=n;i++) q1[n+1-i][0]=a[i];
for(register ll mx,id,i=1;i<=m;++i)
{
mx=0;
if(l1<=r1&&mx<q1[l1][0]+(i-q1[l1][1]-1)*q) mx=q1[l1][0]+(i-q1[l1][1]-1)*q,id=1;
if(l2<=r2&&mx<q2[l2][0]+(i-q2[l2][1]-1)*q) mx=q2[l2][0]+(i-q2[l2][1]-1)*q,id=2;
if(l3<=r3&&mx<q3[l3][0]+(i-q3[l3][1]-1)*q) mx=q3[l3][0]+(i-q3[l3][1]-1)*q,id=3;
if(i%t==0) printf("%lld ",mx);
if(id==1) ++l1;if(id==2) ++l2;if(id==3) ++l3;
q2[++r2][0]=mx*u/v,q2[r2][1]=i;
q3[++r3][0]=mx-mx*u/v,q3[r3][1]=i;
}
printf("\n");ll i=0;
while(l1<=r1||l2<=r2||l3<=r3)
{
ll id,mx=0;++i;
if(l1<=r1&&mx<q1[l1][0]+(m-q1[l1][1])*q) mx=q1[l1][0]+(m-q1[l1][1])*q,id=1;
if(l2<=r2&&mx<q2[l2][0]+(m-q2[l2][1])*q) mx=q2[l2][0]+(m-q2[l2][1])*q,id=2;
if(l3<=r3&&mx<q3[l3][0]+(m-q3[l3][1])*q) mx=q3[l3][0]+(m-q3[l3][1])*q,id=3;
if(i%t==0) printf("%lld ",mx);
if(id==1) ++l1;if(id==2) ++l2;if(id==3) ++l3;
}
printf("\n");
return 0;
}
2018.9.1
洛谷 P2827 蚯蚓 解题报告的更多相关文章
- 洛谷P2827 蚯蚓 题解
洛谷P2827 蚯蚓 题解 题目描述 本题中,我们将用符号 ⌊c⌋ 表示对 c 向下取整. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓. 蛐蛐国里现 ...
- NOIP 2016 洛谷 P2827 蚯蚓 题解
题目传送门 展开 题目描述 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳 蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手 ...
- 洛谷 P2058 海港 解题报告
P2058 海港 题目描述 小K是一个海港的海关工作人员,每天都有许多船只到达海港,船上通常有很多来自不同国家的乘客. 小K对这些到达海港的船只非常感兴趣,他按照时间记录下了到达海港的每一艘船只情况: ...
- 洛谷 P3956 棋盘 解题报告
P3956 棋盘 题目描述 有一个\(m×m\)的棋盘,棋盘上每一个格子可能是红色.黄色或没有任何颜色的.你现在要从棋盘的最左上角走到棋盘的最右下角. 任何一个时刻,你所站在的位置必须是有颜色的(不能 ...
- 洛谷 P1979 华容道 解题报告
P1979 华容道 题目描述 小\(B\)最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少需要多少时 ...
- BZOJ 3545 / 洛谷 P4197 Peaks 解题报告
P4197 Peaks 题目描述 在\(\text{Bytemountains}\)有\(N\)座山峰,每座山峰有他的高度\(h_i\).有些山峰之间有双向道路相连,共\(M\)条路径,每条路径有一个 ...
- 洛谷——P2827 蚯蚓
P2827 蚯蚓 题目描述 本题中,我们将用符号 \lfloor c \rfloor⌊c⌋ 表示对 cc 向下取整,例如:\lfloor 3.0 \rfloor = \lfloor 3.1 \rflo ...
- 虔诚的墓主人(BZOJ1227)(洛谷P2154)解题报告
题目描述 小W是一片新造公墓的管理人.公墓可以看成一块N×M的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地. 当地的居民都是非常虔诚的基督徒,他们愿意提前为自己找一块合适墓地. ...
- 洛谷P2827 蚯蚓——思路题
题目:https://www.luogu.org/problemnew/show/P2827 思路... 用优先队列模拟做的话,时间主要消耗在每次的排序上: 能不能不要每次排序呢? 关注先后被砍的两条 ...
随机推荐
- Asp.Net Core 使用Docker进行容器化部署(二)使用Nginx进行反向代理
上一篇介绍了Asp.Net 程序在Docker中的部署,这篇介绍使用Nginx对Docker的实例进行反向代理 一.修改Nginx配置文件 使用winscp链接Liunx服务器,在/ect/nginx ...
- PHP实现微信红包算法和微信红包的架构设计简介
微信红包的架构设计简介: 原文:https://www.zybuluo.com/yulin718/note/93148 @来源于QCon某高可用架构群整理,整理朱玉华. 背景:有某个朋友在朋友圈咨询微 ...
- mysql在cmd里中文乱码解决办法
右边画红线部分中文已经乱码,左边红线里中文则完美显示出来了. 解决办法 用set names utf-8: 效果如图
- u-boot、kernel、root系统烧写和挂载命令命令
一.uboot 环境变量: 1. 打印环境变量:# print 2. 设置启动参数# set bootargs noinitrd init=/linuxrc console=ttySAC0,11520 ...
- vue---day02
1. 全局组件的注册 - 创建根实例的时候,data可以是object,也可以是函数 - 创建组件的时候,data必须是函数 1.1 创建 Vue.component('global-componen ...
- 线程基础四 使用Monitor类锁定资源
前面我们讲过了lock的用法以及竞争条件导致的错误,实际上lock关键字是Monitor类用例的一个语法糖.如果我们分解使用了lock关键字的代码,将会看到它如下面代码片段所示: bool acqui ...
- spring、spring-data-redis整合使用
一.Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 从2010年3月15日起,Redis的开发工作由VMwa ...
- mutation与vuex区别
vuex- action 1.当点发送过快,页面中渲染的内容与state中的数据不一致,vuex里面的state变得慢,且不持续更新 2.action中是可以做到页面中state中数据保持一致 责 ...
- 使用IDEA快速搭建Gradle项目
- kvm-1
yum install libvirt* virt-* qemu-kvm* -y systemctl start libvirtd.service systemctl status libvirtd. ...