大顶堆与小顶堆应用---寻找前k小数

 1 vector<int>  getLeastNumber(vector<int>&  arr,int k){
 2 vector<int> vec(k,0);
 3 if(0==k)
 4 return vec;
 5 priority_queue<int> q;
 6 for(int i = 0;i < k;i++){
 7 q.push(arr[i]);
 8 }
 9 for(int i = k;i <(int)arr.size();i++){
10 if(q.top()>arr[i]){
11 q.pop();
12 q.push(arr[i]);
13 }
14 }
15 for(int i = 0;i < k;i++){
16 vec[i] = q.top();
17 q.pop();
18 }
19 return vec;
20 }

我们用一个大根堆实时维护数组的前 kk 小值。首先将前 kk 个数插入大根堆中,随后从第 k+1k+1 个数开始遍历,如果当前遍历到的数比大根堆的堆顶的数要小,就把堆顶的数弹出,再插入当前遍历到的数。最后将大根堆里的数存入数组返回即可。

一:优先级队列

  比如在一组数组中,规定最大值先出或最小值先出,并按照这个约束一次出队。

二:定义方式

1:小顶堆及基本实现机制

  节点值越小的越在前面。实现机制主要采用二叉树/二叉堆等。

2:大顶堆及基本实现机制

  节点值越大越在前面。

priority-queue<int> p;//最大值优先,大顶堆的简写方式
priority-queue<int,vector<int>,greater<int> > q1;//最小值优先,小顶堆
priority-queue< int,vector<int>,less<int> > q2;//最大值优先,大顶堆

//第一个参数--数据类型,第二个参数--容器类型,第三个参数--比较函数
}

{
//结构体的优先级比较方式

struct node{
string name;
int price;
friend bool operator < (node a,node b)
{
return a.price < b.price;
}
//相当于less,这是大顶堆,反之是小顶堆,最大值优先
}stu;

priority-queue<node> q;

三:常用操作
q.push(x);
q.pop();
q.top();
q.size();
q.empty();
}

{
四:举例
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <queue>
#include <stack>
#include <vector>

using namespace std;

struct node
{
friend bool operator< (node n1,node n2)
{
return (n1.priority < n2.priority);
}

int priority;
int value;
};

int main()
{
const int len = 5;
int i;
int a[len] = {3,5,9,6,2};

//从大到小输出
priority-queue<int> q1;
for (int i = 0;i < len;i++)
q1.push[a[i]);

for (int i = 0;i < len;i++)
{
cout << q1.top() << " ";
q1.pop();
}
cout << endl;

//从小到大输出
priority-queue<int,vector<int>,greater<int> > q2;
for (int i = 0;i < len;i++)
q2.push(a[i]);

for (int i = 0;i < len;i++)
{
cout << q2.top() << " ";
q2.pop();
}
cout << endl;

//按优先级输出
priority-queue<node> qn;
node b[len];
b[0].priority = 6;b[0].value = 1;
b[1].priority = 9;b[1].value = 5;
b[2].priority = 2;b[2].value = 3;
b[3].priority = 8;b[3].value = 2;
b[4].priority = 1;b[4].value = 4;

for (int i = 0;i < len;i++)
qn.push(b[i]);

cout << "优先级" << '\t' << "值" << endl;
for (int i = 0;i < len;i++)
{
cout << qn.top().priority << '\t' << qn.top().value << endl;
qn.pop();
}
cout << endl;

}
}

posted @ 2020-05-30 16:27  糖糖_彭  阅读(555)  评论(0编辑  收藏  举报