题意:

按照顺序给你n个数,当数的数量是奇数的时候就输出它们的中位数

题解:

优先队列默认是大顶堆,即priority_queue.top()是这个队列中的最大值

那么我们就可以先创造一个大顶堆优先队列qmax,和一个小顶堆qmin

qmin里面放的是大于等于中位数的数,qmax里面放的是比中位数小的数
因为qmin是小顶堆,那么qmin.top()肯定就是中位数
(上面的话是在中位数的前提下)

代码:

  1. 1 #include <bits/stdc++.h>
  2. 2 using namespace std;
  3. 3 int main()
  4. 4 {
  5. 5 int t;
  6. 6 scanf("%d",&t);
  7. 7 while(t--)
  8. 8 {
  9. 9 priority_queue<int > qmax; //大顶堆
  10. 10 priority_queue<int ,vector<int > ,greater <int > >qmin; //小顶堆
  11. 11 int cnt;
  12. 12 int n;
  13. 13 scanf("%d%d",&cnt,&n);
  14. 14 printf("%d %d\n",cnt,(n/2+1));
  15. 15 for(int i=1;i<=n;i++)
  16. 16 {
  17. 17 int mid;
  18. 18 scanf("%d",&mid);
  19. 19 if(qmin.size()==0)
  20. 20 qmin.push(mid);
  21. 21 else
  22. 22 {
  23. 23 if(mid>qmin.top())
  24. 24 qmin.push(mid);
  25. 25 else qmax.push(mid);
  26. 26 }
  27. 27 while(qmin.size()!=qmax.size() && qmin.size()!=qmax.size()+1) //这两个条件任意一个不满足就要跳出来
  28. 28 {
  29. 29 if(qmax.size()>qmin.size())
  30. 30 {
  31. 31 int x=qmax.top();
  32. 32 qmax.pop();
  33. 33 qmin.push(x);
  34. 34 }
  35. 35 else
  36. 36 {
  37. 37 int x=qmin.top();
  38. 38 qmin.pop();
  39. 39 qmax.push(x);
  40. 40 }
  41. 41 }
  42. 42 /*
  43. 43 经过上面的while处理后,qmin里面放的是大于等于中位数的数,qmax里面放的是比中位数小的数
  44. 44 因为qmin是小顶堆,那么qmin.top()肯定就是中位数
  45. 45 (上面的话是在中位数的前提下)
  46. 46 */
  47. 47 if(i&1)
  48. 48 cout << qmin.top();
  49. 49 if((i+1)%20==0||i==n)
  50. 50 cout << endl;
  51. 51 else if(i&1)
  52. 52 cout << " ";
  53. 53 }
  54. 54 }
  55. 55 return 0;
  56. 56 }

HDU - 3282 优先队列的使用的更多相关文章

  1. hdu 3282 Running Median

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=3282 Running Median Description For this problem, you ...

  2. HDU 3282 Running Median 动态中位数,可惜数据范围太小

    Running Median Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pi ...

  3. hdu 5306 优先队列

    用到优先队列 #include<iostream> #include<string> #include<algorithm> #include<cstdio& ...

  4. HDU 4006 优先队列

    The kth great number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Oth ...

  5. hdu 5818 (优先队列) Joint Stacks

    题目:这里 题意: 两个类似于栈的列表,栈a和栈b,n个操作,push a x表示把数x放进a栈的栈底,pop b 表示将栈b的栈顶元素取出输出,并释放这个栈顶元素,merge a b表示把后面的那个 ...

  6. hdu 4302 优先队列

    进一步学习了优先队列的用法 题意:一只小动物在直线上走,起始位置为零,之后会出现食物,动物要去距离自己最短的食物那,若两边的食物距离相等,则选择之前走的方向的食物 0 x,代表x的位置出现了食物,1代 ...

  7. hdu 4393 优先队列

    用优先队列储存每个人的初始距离和编号,每轮求出最快的人,然后pop掉 一开始想遍历队列的,后来发现队列没办法遍历,汗-_-! 题意,给几个第一秒冲出的距离和以后速度,求每秒后最前面人的编号,求完后最前 ...

  8. HDU 1058 优先队列or堆

    本来应当是一道优先队列或者堆的题 因为每个数都应该是已经得到的数*2 *3 *5 *7而得到的 但是 2*7 大于 3*2 这就必须保证每次取得都是没有拿过的最小的数 但是它主动降低难度在样例里卖了个 ...

  9. hdu 2258 优先队列

    Continuous Same Game (1) Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

随机推荐

  1. 断言封装之key检查及kv实战示例

    ️️️️️️️️️️️️️️️️️️️️️️️️️️️️️ 测试: 断言处理: demo_04.pyimport jsonjson_obj = {"access_token":&q ...

  2. nodejs中的文件系统

    . 目录 简介 nodejs中的文件系统模块 Promise版本的fs 文件描述符 fs.stat文件状态信息 fs的文件读写 fs的文件夹操作 path操作 简介 nodejs使用了异步IO来提升服 ...

  3. Centos搭建Git服务端

    首先需要安装git,可以使用yum源在线安装 yum install -y git 创建一个git用户,用来运行管理git服务 adduser git 初始化git仓库(这里我们选择/home/git ...

  4. 浅入深出了解XXE漏洞

    环境搭建 https://github.com/c0ny1/xxe-lab 为了更深入的理解,我准备理论和实际相结合的了解XXE! 浅谈XML 初识XML 一个好的代码基础能帮助你更好理解一类漏洞,所 ...

  5. SAPLink 非常好用的工具

    对于SAP LINK,如果你想将一个程序完整的保存到本地,包括程序的自定义屏幕.菜单等等,那么请使用这个工具,它能够将一个程序完整的保存下来,并且移植到另一个SAP系统中,用来左程序的迁移和本地保存备 ...

  6. js千分位分隔,数字货币化方法学习记录

    js千分位分隔,数字货币化-4种方法(含正则) 方法1-整数货币化 // 整数货币化 function intCurrency(num) { var reg = new RegExp("^[ ...

  7. GlusterFS数据存储脑裂修复方案最全解析

    本文档介绍了glusterfs中可用于监视复制卷状态的heal info命令以及解决脑裂的方法 一. 概念解析 常见术语 名称 解释 Brick GlusterFS 的基本存储单元,由可信存储池中服务 ...

  8. Xamarin.Forms: 无限滚动的ListView(懒加载方式)

    说明 在本博客中,学习如何在Xamarin.Forms应用程序中设计一个可扩展的无限滚动的ListView.这个无限滚动函数在默认的Xamarin.Forms不存在,因此我们需要为此添加插件.在这里我 ...

  9. windows10 中 svn 代码统计工具 StatSVN 使用详解

    1.下载TortoiseSVN 下载地址 ps:安装时务必选上命令行的svn命令. 2.下载StatSVN 官网地址 官网上目前时0.7.0版本,我的svn是1.12.0版本,运行时会报错: 所以建议 ...

  10. 从零开始学Java (一)环境配置

    1.下载jdk Oracle官网 2.配置环境变量 JAVA_HOME:指明JDK安装路径,如C:\Program Files\Java\jdk1.7.0Path:变量中添加 %JAVA_HOME%\ ...