POJ 1442 优先队列 模板

/*
poj 1442
题意:给定M个数,每次可以插入序列一个数;再给N个数,表示在插入第几个数时输出一个数,
   第一次输出序列中最小的,第二次输出序列中第二小的……以此类推,直到输出N个数。
优先队列的使用:
本题思路是建立一个小顶堆p和一个大顶堆q,
q保存前k个小的数,且保证p的值都比q的大,
最后输出q的顶
*/
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <queue>
using namespace std;
int main()
{
    int n,m,i,a[31000];
    cin>>m>>n;
    for(i=0; i<m; i++)
        scanf("%d",&a[i]);
    int num=1,b1=0,b2,j=0,s,k=1;
    priority_queue<int ,vector<int>,greater<int> >p;/*小顶堆,即从小到大*/
    priority_queue<int ,vector<int>,less<int> >q;
    while(n--)
    {
        scanf("%d",&b2);
        while(b1<b2)/*先把数都放在p队列中,是为了维持q队列中的k个数*/
            p.push(a[b1++]);
        while(!q.empty()&&p.top()<q.top()) {/*保证p中的数都比q中的数大,否则交换*/
            int x=q.top();
            q.pop();
            q.push(p.top());
            p.pop();
            p.push(x);
        }
        cout<<p.top()<<endl;
        q.push(p.top());/*把第k小的数放入q中,保持q的个数*/
        p.pop();
    }
    return 0;
}
时间: 2024-11-08 22:21:24

POJ 1442 优先队列 模板的相关文章

POJ 1442 优先队列

题意:有一些ADD和GET操作.n次ADD操作,每次往序列中加入一个数,由ADD操作可知序列长度为1-n时序列的组成.GET操作输入一个序列长度,输出当前长度序列第i大的元素的值.i初始为0,每次GET操作i先加1.给出的GET操作输入非降. 思路:求长度为k的序列的第i大元素.优先队列维护最大堆和最小堆分别存放前i-1大的元素和第i-第k大的元素.将当前序列的元素压入最小堆,如果最小堆的最小数大于最大堆的最大数则进行交换,保证最大堆中的所有数小于最小堆.因为i值每进行一次自增1,所以每次GET

[ACM] POJ 1442 Black Box (堆,优先队列)

Black Box Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 7099   Accepted: 2888 Description Our Black Box represents a primitive database. It can save an integer array and has a special i variable. At the initial moment Black Box is empt

POJ 1442 Black Box(优先队列)

题目地址:POJ 1442 这题是用了两个优先队列,其中一个是较大优先,另一个是较小优先.让较大优先的队列保持k个.每次输出较大优先队列的队头. 每次取出一个数之后,都要先进行判断,如果这个数比较大优先的队列的队头要小,就让它加入这个队列,队列头移到较小优先的队列中.然后当较大优先的数不足k个的时候,就让较小优先的队列的队头移到较大优先的队头中. 代码如下: #include <iostream> #include <cstdio> #include <string>

连接(应该可以这么说吧)优先队列——POJ 1442

对应POJ题目:点击打开链接 Black Box Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit Status Description Our Black Box represents a primitive database. It can save an integer array and has a special i variable. At the initial m

【POJ 1442】 Black Box

[POJ 1442] Black Box 向一个恒递增序列中加数 一开始序列为空 不断加m个数 有n个询问 x1x2x3-xi每次个询问表示加第x个数后 第i小的数是几 两个优先队列进行维护 一个递增一个递减 令递增队列对首为当前第i小的数 因此递减队列需要存i前的数 每当序列需要加一个数时 先与递减队列比较 如果比递减队列队首(前i-1个数中最大的数)小 将该数入递减队列 把递减队列对首拿出加入递增队列 此时递增队列队首即为当前第i小的数 如果比递减队列队首大 直接加入递增队列 递增队列对首为

poj 1442 -- Black Box

Black Box Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 7183   Accepted: 2920 Description Our Black Box represents a primitive database. It can save an integer array and has a special i variable. At the initial moment Black Box is empt

POJ 1442 Black Box treap求区间第k大

题目来源:POJ 1442 Black Box 题意:输入xi 输出前xi个数的第i大的数 思路:试了下自己的treap模版 #include <cstdio> #include <cstring> #include <cstdlib> #include <ctime> using namespace std; struct Node { Node *ch[2]; int r; int v; int s; Node(){} Node(int v): v(v)

poj 1442 Black Box (treap树入门题)

1 /**************************************************** 2 题目: Black Box(poj 1442) 3 链接: http://poj.org/problem?id=1442 4 题意: 给n个数,m个询问,对第i数个询问前Xi个数中第 5 i小的是那个数. 6 算法: treap树 7 *****************************************************/ 8 #include<iostream

POJ 1113 凸包模板题

上模板. #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #include <cmath> #include <vector> #include <utility> #include <stack> #include <queue> #include <map> #include