zoukankan      html  css  js  c++  java
  • 大顶堆与小顶堆应用---寻找前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 << "优先级" << ' ' << "值" << endl;
    for (int i = 0;i < len;i++)
    {
    cout << qn.top().priority << ' ' << qn.top().value << endl;
    qn.pop();
    }
    cout << endl;

    }
    }

  • 相关阅读:
    生成随机串码并保存到Excel中
    制作100份word表
    抓取网页图片-以本地IIS网页为实践对象
    使用xlsxwriter 创建图表chart
    照片查看器2.0
    编程注意事项-记踩过的坑
    STC12C5A60S2的定时器模式16位的时候没有自动重载功能
    Keil C51 一个警告 '=': pointer: different mspace
    RT-Thread 使用笔记二
    Keil-C51读取ROM数据
  • 原文地址:https://www.cnblogs.com/pengtangtang/p/12993372.html
Copyright © 2011-2022 走看看