刚看到这道题:这题直接用堆+模拟不就可以了(并没有认真算时间复杂度)

于是用priority_queue水到了85分…… (STL大法好)

天真的我还以为是常数问题,于是疯狂卡常……(我是ZZ)

直到我下了组数据,结果它跑了……跑了……10s (这叫我怎么卡常)

OK,闲聊到次结束,接下来说正解


其实这道题并不需要用堆,因为我们可以蚯蚓其实是满足单调性的,因为后切的蚯蚓一定要比先切的短,所以堆是不必要的,我们只用三个队列,分别记录没被切的蚯蚓、被切了的短的蚯蚓、被切了的长的蚯蚓,每次把三个队列的队头取出来比较,切掉最长的,再分别入队。

时间复杂度:\(O(n+m)\)

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. #include<queue>
  6. using namespace std;
  7. int read(){
  8. int k=0,f=1; char c=getchar();
  9. for(;c<'0'||c>'9';c=getchar())
  10. if(c=='-') f=-1;
  11. for(;c>='0'&&c<='9';c=getchar())
  12. k=(k<<3)+(k<<1)+c-48;
  13. return k*f;
  14. }
  15. double p;
  16. int qy[100010],cut1[10000010],cut2[10000010];
  17. int h=1,ta,h1=1,t1,h2=1,t2;
  18. bool cmp(int x,int y){
  19. return x > y;
  20. }
  21. int main(){
  22. //freopen("hhh.in","r",stdin);
  23. //freopen("hhh.out","w",stdout);
  24. int n=read(),m=read(),q=read(),u=read(),v=read(),t=read();
  25. memset(cut1,-127,sizeof(cut1));
  26. memset(cut2,-127,sizeof(cut2));
  27. memset(qy,-127,sizeof(qy));
  28. p=(double)u/(double)v; ta=n;
  29. for(int i=1;i<=n;i++) qy[i]=read();
  30. sort(qy+1,qy+n+1,cmp);
  31. for(int i=1;i<=m;i++){
  32. int maxn=-2147483647; bool flag=0;
  33. if(qy[h]>=cut1[h1]&&qy[h]>=cut2[h2]&&h<=ta){
  34. maxn=qy[h]+(i-1)*q; h++; flag=1;
  35. //printf("%d %d\n",h,ta);
  36. }
  37. if(cut1[h1]>=cut2[h2]&&cut1[h1]>=qy[h]&&!flag&&h1<=t1){
  38. maxn=cut1[h1]+(i-1)*q; h1++; flag=1;
  39. //printf("%d %d\n",h1,t1);
  40. }
  41. if(cut2[h2]>=cut1[h1]&&cut2[h2]>=qy[h]&&!flag&&h2<=t2){
  42. maxn=cut2[h2]+(i-1)*q; h2++; flag=1;
  43. //printf("%d %d\n",h2,t2);
  44. }
  45. //printf("%d %d %d\n",qy[h],cut1[h1],cut2[h2]);
  46. if(i%t==0) printf("%d ",maxn);
  47. int k=maxn*p;
  48. cut1[++t1]=k-i*q; cut2[++t2]=maxn-k-i*q;
  49. }
  50. printf("\n");
  51. for(int i=1;i<=n+m;i++){
  52. int maxn=-2147483647; bool flag=0;
  53. if(qy[h]>=cut1[h1]&&qy[h]>=cut2[h2]&&h<=ta){
  54. maxn=qy[h]+m*q; h++; flag=1;
  55. }
  56. if(cut1[h1]>=cut2[h2]&&cut1[h1]>=qy[h]&&!flag&&h1<=t1){
  57. maxn=cut1[h1]+m*q; h1++; flag=1;
  58. }
  59. if(cut2[h2]>=cut1[h1]&&cut2[h2]>=qy[h]&&!flag&&h2<=t2){
  60. maxn=cut2[h2]+m*q; h2++; flag=1;
  61. }
  62. if(i%t==0)
  63. printf("%d ",maxn);
  64. }
  65. return 0;
  66. }

Noip2016 提高组 蚯蚓的更多相关文章

  1. [NOIp2016提高组]蚯蚓

    题目大意: 给你n个不同长度蚯蚓,每秒从里面取出最长的砍下u/v变成两只,又把剩下的加长q. 问你在m之前的t,2t,3t...的时间上,砍的蚯蚓长度, 以及m秒后剩下所有的蚯蚓长度. 思路: 很容易 ...

  2. Luogu P2827 [NOIp2016提高组]蚯蚓 | 神奇的队列

    题目链接 80分思路: 弄一个优先队列,不停地模拟,切蚯蚓时就将最长的那一条出队,然后一分为二入队,简单模拟即可.还要弄一个标记,表示从开始到当前时间每一条蚯蚓应该加上的长度,操作时就加上,入队时就减 ...

  3. 洛谷P2827 [NOIP2016 提高组] 蚯蚓 (二叉堆/队列)

    容易想到的是用二叉堆来解决,切断一条蚯蚓,其他的都要加上一个值,不妨用一个表示偏移量的delta. 1.取出最大的x,x+=delta: 2.算出切断后的两个新长度,都减去delta和q: 3.del ...

  4. 【题解】NOIP2016提高组 复赛

    [题解]NOIP2016提高组 复赛 传送门: 玩具谜题 \(\text{[P1563]}\) 天天爱跑步 \(\text{[P1600]}\) 换教室 \(\text{[P1850]}\) 组合数问 ...

  5. 【题解】NOIP2016 提高组 简要题解

    [题解]NOIP2016 提高组 简要题解 玩具迷题(送分) 用异或实现 //@winlere #include<iostream> #include<cstdio> #inc ...

  6. NOIP2016提高组解题报告

    NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合

  7. [日记&做题记录]-Noip2016提高组复赛 倒数十天

    写这篇博客的时候有点激动 为了让自己不颓 还是写写日记 存存模板 Nov.8 2016 今天早上买了两个蛋挞 吃了一个 然后就做数论(前天晚上还是想放弃数论 但是昨天被数论虐了 woc noip模拟赛 ...

  8. 【NOIP2016提高组day2】蚯蚓

    那么我们开三个不上升队列, 第一个记录原来的蚯蚓, 第二个记录乘以p的蚯蚓 第三个记录乘以(1-p)的蚯蚓, 在记录每条就要入队列的时间,就可以求出增加的长度 每次比较三个队列的队首,取最大的值x的切 ...

  9. 【NOIP2016提高组】 Day2 T2 蚯蚓

    题目传送门:https://www.luogu.org/problemnew/show/P2827 自测时被题面所误导...,题面中说逢t的倍数才输出答案,以为有什么玄妙的方法直接将m次操作变成了m/ ...

随机推荐

  1. 一个github搞定微信小程序支付系列

    详情请前往github下载示例代码 源码中包含 支付.退款 功能 so easy,项目经理再也不用担心微信支付啦 是的,已经over了

  2. 51nod1640 【最小生成树】

    题意: 在一副图中,搞N-1条边,使得每个点都相连, 有多种可能的情况,所以求一种使得其中n-1条边的最大是所有可能的最小,然后并保证连接的n-1条边的权值总和最大 思路: 一开始没有看清题意,随便写 ...

  3. MongoDb 安装服务 以及 安全配置

    安装MongoDb 的服务 命令如下: (cmd以管理员运行) mongod –logpath "D:\Program Files\mongodb\data\logs.txt" – ...

  4. 进击python第三篇:基础

    基础拾遗 序列解包 例: >>>x,y,z=1,2,3 >>>print x,y,z 1 2 3 交换变量也是没问题 >>>x,y=y,x > ...

  5. Xmind8 Pro 思维导图制作软件,傻瓜式安装激活教程

    xmind 是做思维导图的软件?今天有一个以前的同事还在和我要这个软件,当然我支持正版啊 !因为正版好用! 我是一个不爱说废话的人,就顺便分享一下 给大家用! 软件下载地址: 链接:https://p ...

  6. Nginx 405 not allowed最简单快速解决办法

    Apache.IIS.Nginx等绝大多数web服务器,都不允许静态文件响应POST请求,否则会返回“HTTP/1.1 405 Method not allowed”错误. server { list ...

  7. jave之set和get的用法

    package com.xxl.api.admin; public class Test { private int score; public int getScore() { return sco ...

  8. 牛客小白月赛13 E(图、矩阵幂)

    AC通道 如果建立第一天某点到某点有几条路的矩阵,做k次矩阵乘就是第k天某点到某点有几条路.统计即可. #include <bits/stdc++.h> using namespace s ...

  9. Codeforces 997D(STL+排序)

    D. Divide by three, multiply by two time limit per test 1 second memory limit per test 256 megabytes ...

  10. 最耗资源的10条sql

    ----当前最耗资源的10个cpu select * from (select address,hash_value, round(cpu_time/1000000) cpu_time_s, roun ...