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的好成绩。

  1. // luogu-judger-enable-o2
  2. #include<bits/stdc++.h>
  3.  
  4. #define N 51000110
  5. using namespace std;
  6.  
  7. int n,m,q,u,v,t,size,fq,heap[N];
  8. double p;
  9. //priority_queue<int,vector<int> >Q;
  10.  
  11. struct node{
  12. void push(int x){
  13. int now,next;
  14. heap[++size]=x;
  15. now=size;
  16. while(now>){
  17. next=now>>;
  18. if(heap[next]>=heap[now]) break;
  19. swap(heap[next],heap[now]);
  20. now=next;
  21. }
  22. }
  23. int top(){
  24. int now=,next,ans;
  25. ans=heap[];
  26. heap[]=heap[size--];
  27. while(now*<=size){
  28. next=now*;
  29. if(next<size&&heap[next+]>heap[next]) next++;
  30. if(heap[now]>heap[next]) break;
  31. swap(heap[now],heap[next]);
  32. now=next;
  33. }return ans;
  34. }
  35. }Q;
  36.  
  37. int main() {
  38. scanf("%d%d%d%d%d%d",&n,&m,&q,&u,&v,&t);
  39. p=(double)u/v;
  40. for(int x,i=; i<=n; i++) {
  41. scanf("%d",&x);
  42. Q.push(x);
  43. }
  44. for(int i=; i<=m; i++) {
  45. int top=Q.top();
  46. top+=fq;
  47. if(i%t==) printf("%d ",top);
  48. int a=top*p,b=top-a;
  49. fq+=q;
  50. a-=fq,b-=fq;
  51. Q.push(a);
  52. Q.push(b);
  53. }
  54. // printf("%d\n",size);
  55. puts("");
  56. for(int i=;i<=n+m;i++){
  57. int an=Q.top();
  58. an+=fq;
  59. if(i%t==) printf("%d ",an);
  60. }
  61. return ;
  62. }

仔细观察一下,你就会发现隐含的单调性,假设先被切掉的为$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>...$

那么就可以模拟了,每次取三个堆中的最大值即可

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4.  
  5. #define N 14010100
  6. using namespace std;
  7.  
  8. int n,m,q,u,v,t,Q[][N];
  9. double p;
  10.  
  11. bool cmp(int x,int y){
  12. return x>y;
  13. }
  14.  
  15. int main() {
  16. // freopen("2827.in","r",stdin);
  17. // freopen("2827.out","w",stdout);
  18. scanf("%d%d%d%d%d%d",&n,&m,&q,&u,&v,&t);
  19. p=(double)u/v;
  20.  
  21. for(int i=;i<=n+;i++) Q[][i]=Q[][i]=Q[][i]=-0x7fffffff;
  22.  
  23. for(int i=; i<=n; i++) scanf("%d",&Q[][i]);
  24. sort(Q[]+,Q[]++n,cmp);
  25.  
  26. int top_1,top_2,top_3,fq=,tail_2,tail_3;
  27. top_1=top_2=top_3=;
  28. tail_2=tail_3=;
  29.  
  30. for(int i=; i<=m; i++) {
  31. int top=-0x7fffffff;
  32. if(top_1<=n) top=max(Q[][top_1],top);
  33. if(top_2<=tail_2) top=max(Q[][top_2],top);
  34. if(top_3<=tail_3) top=max(Q[][top_3],top);
  35.  
  36. if(top==Q[][top_1]&&top_1<=n) top_1++;
  37. else if(top==Q[][top_2]&&top_2<=tail_2) top_2++;
  38. else top_3++;
  39.  
  40. top+=fq;
  41. if(i%t==) printf("%d ",top);
  42. int a=top*p,b=top-a;
  43. fq+=q;
  44. a-=fq,b-=fq;
  45. Q[][++tail_2]=b;
  46. Q[][++tail_3]=a;
  47. }
  48. puts("");
  49.  
  50. for(int i=;i<=n+m;i++){
  51. int top=-0x7fffffff;
  52. if(top_1<=n) top=max(Q[][top_1],top);
  53. if(top_2<=tail_2) top=max(Q[][top_2],top);
  54. if(top_3<=tail_3) top=max(Q[][top_3],top);
  55.  
  56. if(top==Q[][top_1]&&top_1<=n) top_1++;
  57. else if(top==Q[][top_2]&&top_2<=tail_2) top_2++;
  58. else top_3++;
  59.  
  60. if(i%t==) printf("%d ",top+fq);
  61. }
  62.  
  63. return ;
  64. }

洛谷——P2827 蚯蚓的更多相关文章

  1. 洛谷P2827 蚯蚓 题解

    洛谷P2827 蚯蚓 题解 题目描述 本题中,我们将用符号 ⌊c⌋ 表示对 c 向下取整. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓. 蛐蛐国里现 ...

  2. NOIP 2016 洛谷 P2827 蚯蚓 题解

    题目传送门 展开 题目描述 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」=[3.9」=3.蛐蛐国最近蚯蚓成灾了!隔壁跳 蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手 ...

  3. 洛谷 P2827 蚯蚓 解题报告

    P2827 蚯蚓 题目描述 本题中,我们将用符号 \(\lfloor c \rfloor\) 表示对 \(c\) 向下取整,例如:\(\lfloor 3.0 \rfloor = \lfloor 3.1 ...

  4. 洛谷P2827 蚯蚓——思路题

    题目:https://www.luogu.org/problemnew/show/P2827 思路... 用优先队列模拟做的话,时间主要消耗在每次的排序上: 能不能不要每次排序呢? 关注先后被砍的两条 ...

  5. 洛谷 P2827 蚯蚓

    题目描述 本题中,我们将用符号\lfloor c \rfloor⌊c⌋表示对c向下取整,例如:\lfloor 3.0 \rfloor= \lfloor 3.1 \rfloor=\lfloor 3.9 ...

  6. 洛谷P2827 蚯蚓(单调队列)

    题意 初始时有$n$个蚯蚓,每个长度为$a[i]$ 有$m$个时间,每个时间点找出长度最大的蚯蚓,把它切成两段,分别为$a[i] * p$和$a[i] - a[i] * p$,除这两段外其他的长度都加 ...

  7. 洛谷p2827蚯蚓题解

    题目 算法标签里的算法什么的都不会啊 什么二叉堆?? qbxt出去学习的时候讲的,一段时间之前做的,现在才写到博客上的 维护3个队列,队列1表示最开始的蚯蚓,队列2表示每一次被切的蚯蚓被分开的较长的那 ...

  8. 洛谷 P2827 蚯蚓 题解

    每日一题 day32 打卡 Analysis 我们可以想一下,对于每一秒除了被切的哪一个所有的蚯蚓都增长Q米,我们来维护3个队列,队列1表示最开始的蚯蚓,队列2表示每一次被切的蚯蚓被分开的较长的那一部 ...

  9. 洛谷P2827蚯蚓

    题目 堆+模拟,还有一个小优化(优化后跟堆关系不大,而是类似于贪心). 如果不加优化的话,卡常可以卡到85. 思路是对于对每一秒进行模拟,用堆来维护动态的最大值,然后对于每个长度都加q的情况可以用一个 ...

随机推荐

  1. css3 3d特效汇总

    本篇全是实战,没有基础,如果不明白3d特效的原理,可能会看不懂,不过没关系,给你推荐一下 张鑫旭css3 3d转换,或者看我的另一篇博客  css3 2d转换3d转换以及动画的知识点汇总,看完这些3d ...

  2. YTU 2634: E3 继承了,成员函数却不可访问

    2634: E3 继承了,成员函数却不可访问 时间限制: 1 Sec  内存限制: 128 MB 提交: 521  解决: 435 题目描述 下面的程序中,派生类Derive继承自基类Base,mai ...

  3. 蓝书2.4 AC自动机

    T1 玄武密码 bzoj 4327 题目大意: 一些字符串 求这些字符串的前缀在母串上的最大匹配长度是多少 思路: 对于所有串建立AC自动机 拿母串在自动机上匹配 对所有点打标记 以及对他们的fail ...

  4. DNS的主从、子域授权和转发服务器

    DNS的主从.子域授权和转发服务器 主从DNS 注意: 1.全局配置options{} 里面的内容,其中 listen-on port 53 {any or local:}:或者直接注释掉,或删掉 a ...

  5. bzoj 1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路【Floyd】

    弗洛伊德之后按序列加起来即可 #include<iostream> #include<cstdio> #include<algorithm> using names ...

  6. CSS中路径及form表单的用法

    1.什么是路径? 路劲分为三种 1.绝对路径: 从盘符开始,然后依次的往下查找 本地: C:/Users/Administrator/Desktop/0527day01/07.html 服务器的: w ...

  7. 【题解】PIE [POI2015] [P3585]

    [题解]\(PIE\) \([POI2015]\) \([P3585]\) 逼自己每天一道模拟题 传送门:\(PIE\) \([POI2015]\) \([P3585]\) [题目描述] 一张 \(n ...

  8. 题解报告:hdu 1312 Red and Black(简单dfs)

    Problem Description There is a rectangular room, covered with square tiles. Each tile is colored eit ...

  9. EditText(2)自定义回车键的行为

    1,在android:imeOptions属性中指定要自定义的行为. 系统中有很多行为,如:搜索,完成,下一步等:actionSend,actionGo,actionNext等.下面EditText名 ...

  10. service: no such service mysqld 与MySQL的开启,关闭和重启

    1.问题原因与解决办法 因为修改了MySQL临时文件的目录后,使用service mysqld restart重启MySQL出现如下错误: service: no such service mysql ...