黑匣子

(box.pas/c/cpp)

【 问题描述】

某研究小组成员想发明一个黑匣子( 当然不是飞机上那个), 而是一个具有特殊功能的箱子。 这个箱子具有两个功能: 1. 存放一些正整数 x; 2. 对于第 k 次询问, 它会告诉你箱子中第 k 小的数字是多少。 但光具有理论是不够的, 理论往往应联系实际。 这可是一个大大的难题, 没有丰富程序设计知识的同学们希望你能帮助他们写出这个程序代码, 以便他们能完成黑匣子的制作。

【 输入格式】

第一行, 一个数字 n 表示对黑匣子的操作次数。

以下 n 行, 每行一个数字。 若这个数字是正整数, 则表示在黑匣子中添加这个数字;

若这个数字是­1, 这表示一次询问。

【 输出格式】

若干行, 对应每次询问所得的结果( 必定存在答案)

【 样例输入】

8

1 ­

-1

8

8 ­

-1

5 ­

-1

-1

【 样例输出】

1

8

8

8

【 样例说明】

第一次询问时, 黑匣子内为 1, 输出最小的数 1;

第二次询问时, 黑匣子内为 1 8 8, 输出第二小的数 8;

第三次询问时, 黑匣子内为 1 5 8 8, 输出第三小的数 8;

第四次询问时, 黑匣子内为 1 5 8 8, 输出第四小的数 8。

【 数据范围】

对于30%的数据, 5<=n<=200

对于60%的数据, 5<=n<=10000

对于100%的数据, 5<=n<=100000, n为整数, x为不超过maxlongint的正整数。

这是一道典型的二叉搜索树(平衡树)的题目,但是我们也能用二叉堆的方法来过这道题。//膜拜Y’ADs

首先我们新建两个堆,一个是大根堆,一个是小根堆。

大根堆用于存储前K小个数,小根堆则用于存储其他数.

那么怎样来操作呢?

每读入一个数,与大根堆的TOP(堆头)比较,如果比它小,那么把大根堆的TOP放入小根堆,再将读入的数放入大根堆,即交换。

输出只需要输出小根堆TOP就好了。

再将输出的数从小根堆放入大根堆。

那么我来解释一下为什么可以这样操作。

首先我们已知的两个堆中,大根堆的所有数一定小于小根堆的所有数。大根堆中的数正是前K个数。

接着读入的数如果大于大根堆的TOP,那么这个数就比第K小的数大,只需要放入小根堆就成了(在读入-1时输出)。

但如果它小于大根堆的TOP,证明它小于第K小数。所以把大根堆的数取出来,将读入的数放进去。再将取出的数放入小根堆(在读入-1时输出)。

code

priority_queue <int,vector<int>,greater<int> > x1;
priority_queue <int>x2; for(i=;i<=n;i++)
{
int x=read(),y;
if(x==-)
{
y=x1.top();
printf("%d\n",y);
x2.push(y);
x1.pop();
}
else
{
if(!x2.empty())
{
y=x2.top();
if(x<y){x2.pop();x2.push(x);x1.push(y);}
else x1.push(x);
}
else x1.push(x);
}
}

O(NlogN)

黑匣子_KEY的更多相关文章

  1. Luogu1801_黑匣子_KEY

    题目传送门 借这道题练一下Treap和Splay的板子. code: #include <cstdio> #include <cstdlib> using namespace ...

  2. 塔吊力矩限制器,塔吊黑匣子,塔吊电脑,tower crane

    塔机力矩限制器,tower crane 适用于各种类型的固定臂塔机和可变臂塔机 塔机力矩限制器是塔式起重机机械的安全保护装置,本产品采用32位高性能微处理器为硬件平台,软件算法采用国内最先进的三滑轮取 ...

  3. 代码详解:TensorFlow Core带你探索深度神经网络“黑匣子”

    来源商业新知网,原标题:代码详解:TensorFlow Core带你探索深度神经网络“黑匣子” 想学TensorFlow?先从低阶API开始吧~某种程度而言,它能够帮助我们更好地理解Tensorflo ...

  4. 【洛谷】【堆】P1801 黑匣子_NOI导刊2010提高(06)

    [题目描述:] Black Box是一种原始的数据库.它可以储存一个整数数组,还有一个特别的变量i.最开始的时候Black Box是空的.而i等于0.这个Black Box要处理一串命令. 命令只有两 ...

  5. P1801 黑匣子_NOI导刊2010提高(06)

    P1801 黑匣子_NOI导刊2010提高(06) 题目描述 Black Box是一种原始的数据库.它可以储存一个整数数组,还有一个特别的变量i.最开始的时候Black Box是空的.而i等于0.这个 ...

  6. Luogu P1801 黑匣子_NOI导刊2010提高(06)

    P1801 黑匣子_NOI导刊2010提高(06) 题目描述 Black Box是一种原始的数据库.它可以储存一个整数数组,还有一个特别的变量i.最开始的时候Black Box是空的.而i等于0.这个 ...

  7. 【洛谷P1801】黑匣子

    黑匣子 题目链接 看到题解中“维护两个堆”,突然想到了这道题的解法 维护两个堆:大根堆h1, 小根堆h2 大根堆里的是最小的i个值,小根堆里是剩下的值 每Add一个值时 插入到小根堆中, 再比较小根堆 ...

  8. 洛谷 - P1801 - 黑匣子 - 对顶堆

    这道题是提高+省选-的难度,做出来的话对数据结构题目的理解会增加很多. 可以使用一种叫做对顶堆的东西,对顶堆是在线维护第n小的logn的算法.大概的思路是,假如我们要找的是第n小,我们就维护一个大小为 ...

  9. 洛谷 P1801 黑匣子_NOI导刊2010提高(06)(未完)

    P1801 黑匣子_NOI导刊2010提高(06) 题目描述 Black Box是一种原始的数据库.它可以储存一个整数数组,还有一个特别的变量i.最开始的时候Black Box是空的.而i等于0.这个 ...

随机推荐

  1. Android Studio 独立引入(非友盟)微博分享和回调时问题

    最近同事在做一个小项目时,由于产品的要求,Wap页面的分享规定不能使用友盟的社会化组件.他则不得不手动一个一个渠道的引入分享,好在渠道不多就三个,但是第一微博分享引入的时候问题就出现了. 问题一:li ...

  2. 什么是SAP GUI的client

    我们用SAPGUI登录某个系统时,除了用户名和密码外,还要指定一个必填字段client: 这个client是什么东东? 看文档: SAP Client is the highest hierarchi ...

  3. 跳跃表 SkipList【数据结构】原理及实现

    为什么选择跳表 目前经常使用的平衡数据结构有:B树,红黑树,AVL树,Splay Tree, Treep等. 想象一下,给你一张草稿纸,一只笔,一个编辑器,你能立即实现一颗红黑树,或者AVL树出来吗? ...

  4. Vue.js经典开源项目汇总

    Vue.js经典开源项目汇总 原文链接:http://www.cnblogs.com/huyong/p/6517949.html Vue是什么? Vue.js(读音 /vjuː/, 类似于 view) ...

  5. O(1) 和 O(n) 的区别

    举个简单的例子,要从0加到n,我们会这么写:int sum = 0;for(int i = 0; i<=n; ++i){   sum += i;}一共算了n次加法,那么就说这个时间复杂度是O(n ...

  6. (一)自定义ViewGroup绘制出菜单

    从网上学习了hyman大神的卫星菜单实现,自己特意亲自又写了一编代码,对自定义ViewGroup的理解又深入了一点.我坚信只有自己写出来的知识才会有更加好的的掌握.因此也在自己的博客中将这个卫星菜单的 ...

  7. Kali-linux枚举服务

    枚举是一类程序,它允许用户从一个网络中收集某一类的所有相关信息.本节将介绍DNS枚举和SNMP枚举技术.DNS枚举可以收集本地所有DNS服务和相关条目.DNS枚举可以帮助用户收集目标组织的关键信息,如 ...

  8. argsort

    argsort函数返回的是数组值从小到大的索引值One dimensional array:一维数组 >>> x = np.array([3, 1, 2]) >>> ...

  9. Module、__init__.py 文件解析

    一.什么是Module? 一个python Module就是一个模块,本质就是一个.py文件,其中包含了python对象的定义和python语句. 在模块内部,模块名存储在全局变量__name__中, ...

  10. 二十四、详述 IntelliJ IDEA 中自动生成 serialVersionUID 的方法

    当我们用 IntelliJ IDEA 编写类并实现 Serializable(序列化)接口的时候,可能会遇到这样一个问题,那就是: 无法自动生成serialVersionUID. 而serialVer ...