华师一附中OI组
标题:
NOIP 2016 D2T2 蚯蚓
[打印本页]
作者:
胡雨菲菲
时间:
2018-6-12 16:18
标题:
NOIP 2016 D2T2 蚯蚓
本题中,我们将用符号 LcJ 表示对 c 向下取整,例如: L3.0J = L3.1J = L3.9J = 3 。 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去 请神刀手来帮他们消灭蚯蚓。
蛐蛐国里现在共有 n 只蚯蚓( n 为正整数)。 每只蚯蚓拥有长度,我们设第 i 只匠 蚓的长度为 ai ( i = 1, 2, … , n ),并保证所有的长度都是非负整数(即:可能存在长度为 0 的蚯蚓)。
每一秒,神刀手会在所有的蚯蚓中,准确地找到最长的那一只(如有多个则任选 一个)将其切成两半。 神刀手切开蚯蚓的位置由常数 p (是满足 0 < p < 1 的有理数) 决定,设这只蚯蚓长度为 x ,神刀手会将其切成两只长度分别为 LpxJ 和 x − LpxJ 的匠 蚓。特殊地,如果这两个数的其中一个等于 0 ,则这个长度为 0 的蚯蚓也会被保留。此 外,除了刚刚产生的两只新蚯蚓,其余蚯蚓的长度都会增加q(是一个非负整常数)。
蛐蛐国王知道这样不是长久之计,因为蚯蚓不仅会越来越多,还会越来越长。蛐蛐国王决定求助于一位有着洪荒之力的神秘人物,但是救兵还需要 m 秒才能到来… … ( m 为非负整数)
蛐蛐国王希望知道这 m 秒内的战况。 具体来说,他希望知道: • m 秒内,每一秒被切断的蚯蚓被切断前的长度(有 m 个数): • m 秒后,所有蚯蚓的长度(有 n + m 个数)。 蛐蛐国王当然知道怎么做啦! 但是他想考考你… …
作者:
胡雨菲菲
时间:
2018-6-12 16:18
堆会超时,用三个队列即可
#include <cstdio>
#include <queue>
#include <algorithm>
typedef long long LL;
const int N = 100010;
const LL INF = 1ll << 62;
std::queue<LL> a;
std::queue<LL> b;
std::queue<LL> c;
int m, n, v, u, k, q;
LL d[N], delta;
inline void geta(LL &t) {
t = a.front();
a.pop();
return;
}
inline void getb(LL &t) {
t = b.front();
b.pop();
return;
}
inline void getc(LL &t) {
t = c.front();
c.pop();
return;
}
int main() {
scanf("%d%d%d%d%d%d", &n, &m, &q, &u, &v, &k);
for(int i = 1; i <= n; i++) {
scanf("%lld", &d[i]);
}
std::sort(d + 1, d + n + 1);
for(int i = n; i >= 1; i--) {
a.push(d[i]);
}
for(int i = 1; i <= m; i++) {
LL t;
if(b.empty() && c.empty()) {
geta(t);
}
else if(a.empty()) {
if(b.front() >= c.front()) {
getb(t);
}
else {
getc(t);
}
}
else {
if(a.front() >= b.front() && a.front() >= c.front()) {
geta(t);
}
else if(b.front() >= c.front()) {
getb(t);
}
else {
getc(t);
}
}
t += delta;
if(i % k == 0) {
printf("%lld ", t);
}
LL t1 = t * u / v;
LL t2 = t - t1;
delta += q;
t1 -= delta;
t2 -= delta;
b.push(t1);
c.push(t2);
}
puts("");
a.push(-INF);
b.push(-INF);
c.push(-INF);
for(int i = 1; i <= m + n; i++) {
LL t;
if(a.front() >= b.front() && a.front() >= c.front()) {
geta(t);
}
else if(b.front() >= c.front()) {
getb(t);
}
else {
getc(t);
}
if(i % k == 0) {
printf("%lld ", t + delta);
}
}
return 0;
}
复制代码
欢迎光临 华师一附中OI组 (http://hsyit.cn/)
Powered by Discuz! X3.2