PriorityQueue&&Function overload

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PriorityQueue&&Function overload相关的知识,希望对你有一定的参考价值。

用 STL 里面堆算法实现的与真正的STL里面的 priority_queue用法相似的priority_queue

    #include <iostream>
    #include <algorithm>
    #include <vector>
    
    using namespace std;
    
    class priority_queue
    {
        private:
            vector<int> data;
             
        public:
            void push( int t ){
                data.push_back(t);
                push_heap( data.begin(), data.end());
            }
             
            void pop(){
                pop_heap( data.begin(), data.end() );
                data.pop_back();
            }
             
            int top() { return data.front(); }
            int size() { return data.size(); }
            bool empty() { return data.empty(); }
    };


priority_queue常用的函数:

    top:读入顶端元素
    pop:删除顶端元素
    size:返回元素个数
    push:加入一个元素
    empty:如果为空,返回true
优先级队列(priority_queue)的实现方式是堆(heap), 默认是输出最大值
输出最小值, 需要指定参数, priority_queue<int, vector<int>, greater<int> >

        #include <stdio.h>  
      
        #include <queue>  
        #include <vector>  
        #include <functional>  
              
        using namespace std;  
              
        int main(void)  
        {  
            priority_queue<int, vector<int>, greater<int> > pque;  
              
            pque.push(3);  
            pque.push(5);  
            pque.push(1);  
            pque.push(4);  
              
            while (!pque.empty()) {  
                printf("%d ", pque.top());  
                pque.pop();  
            }  
            printf("\\n");  
              
            return 0;  
        }


C++的函数重载
    http://www.cnblogs.com/skynet/archive/2010/09/05/1818636.html
    http://www.cnblogs.com/yshl-dragon/archive/2013/05/10/3067161.html

以上是关于PriorityQueue&&Function overload的主要内容,如果未能解决你的问题,请参考以下文章

PriorityQueue 到整数数组

Java/优先级队列和构造函数和类型

Heap &amp; Priority Queue

c++中的引用范围是啥? [复制]

定时任务 & 定时线程池 ScheduledThreadPoolExecutor

&&&&数组去重方法总结&&&&&