首页 > 其他 > 详细

P2827 蚯蚓

时间:2018-10-18 22:47:22      阅读:137      评论:0      收藏:0      [点我收藏+]

暴力出奇迹!!!

昨晚很积极地拿手机看这道题的题面,还挺易懂的。

然后写了第二发程序,用优先队列再弄个delta轻轻松松85pts。。。

要是过几天考试能像这样该多好啊。。。


显然那个人挑出所有蚯蚓的最长的,就是堆的基本操作了。

然后想到没有挑出来的蚯蚓是会长长的,但是他们已经在堆里面,用优先队列不可能去修改他们啊!

其实直接维护个变量就可以了。

加新的蚯蚓就要记得减掉这个delta,把蚯蚓拿出来就记得加上这个delta,然后就没问题了。

所以轻松地拿到85pts。。。


为什么不能满分?因为这个\(m\)太大了。

看了题解才知道,这道题还有隐含的单调性:先被切的蚯蚓,长度肯定比后被切的蚯蚓长!

可以很感性地理解。

然后就可以用3个队列(算是单调队列),第一个装原蚯蚓,第二个装被切的短的蚯蚓,第三个装被切的长的蚯蚓。

每一次就从3个队头找出最大值,切掉他,分别扔进第二和第三个队列。

第二问也照着做就是了,没有什么思维难度。


几个小细节:

因为这个delta会越来越大,所以队列中的新蚯蚓的值会越来越小,所以最大值初始化要是负INF而不能是-1。

蚯蚓进第一个队列的时候记得从大到小排序啊!

代码:

#include<cstdio>
#include<cmath>
#include<algorithm>
#include<queue>
#define ll long long
const int maxn = 100005;
const ll INF = 0x3f3f3f3f3f;
ll a[maxn];

std::queue<ll> qq[3];
ll delta = 0;
ll n, m, q, u, v, t;
double p;
bool cmp(ll a, ll b)
{
    return a > b;
}
ll read()
{
    ll ans = 0, s = 1;
    char ch = getchar();
    while(ch > ‘9‘ || ch < ‘0‘){ if(ch == ‘-‘) s = -1; ch = getchar(); }
    while(ch >= ‘0‘ && ch <= ‘9‘) ans = (ans << 3) + (ans << 1) + ch - ‘0‘, ch = getchar();
    return s * ans;
}
int main()
{
    n = read(), m = read(), q = read(), u = read(), v = read(), t = read();
    p = (double)(u) / (double)(v);
    for(int i = 1; i <= n; i++) a[i] = read();
    std::sort(a + 1, a + n + 1, cmp);
    for(int i = 1; i <= n; i++) qq[0].push(a[i]);
    bool first = true;
    for(int i = 1; i <= m; i++)
    {
        ll maxv = -INF, where = -1;
        for(int j = 0; j < 3; j++)
        {
            if(!qq[j].empty() && qq[j].front() > maxv) where = j, maxv = qq[j].front();
        }
        ll x = qq[where].front() + delta; qq[where].pop();
        if(i % t == 0)
        {
            if(first) printf("%lld", x), first = false;
            else printf(" %lld", x);
        }
        ll one = floor(p * x);
        ll other = x - one;
        if(one > other) std::swap(one, other);
        delta += q;
        qq[1].push(one - delta);
        qq[2].push(other - delta);
    }
    printf("\n");
    first = true;
    for(int i = 1; i <= n + m; i++)
    {
        ll maxv = -INF, where = -1;
        for(int j = 0; j < 3; j++)
        {
            if(!qq[j].empty() && qq[j].front() > maxv) where = j, maxv = qq[j].front();
        }
        ll x = qq[where].front() + delta; qq[where].pop();
        if(i % t == 0)
        {
            if(first) printf("%lld", x), first = false;
            else printf(" %lld", x);
        }
    }
    printf("\n");
    return 0;
}

P2827 蚯蚓

原文:https://www.cnblogs.com/Garen-Wang/p/9813446.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!