//: C07:PriorityQueue7.cpp // From "Thinking in C++, Volume 2", by Bruce Eckel & Chuck Allison. // (c) 1995-2004 MindView, Inc. All Rights Reserved. // See source code use permissions stated in the file 'License.txt', // distributed with the code package available at www.MindView.net. // A priority queue that will hand you a vector. #include #include #include #include #include #include #include using namespace std; template class PQV { vector v; Compare comp; public: // Don't need to call make_heap(); it's empty: PQV(Compare cmp = Compare()) : comp(cmp) {} void push(const T& x) { v.push_back(x); // Put it at the end // Re-adjust the heap: push_heap(v.begin(), v.end(), comp); } void pop() { // Move the top element to the last position: pop_heap(v.begin(), v.end(), comp); v.pop_back(); // Remove that element } const T& top() { return v.front(); } bool empty() const { return v.empty(); } int size() const { return v.size(); } typedef vector TVec; TVec getVector() { TVec r(v.begin(), v.end()); // It's already a heap sort_heap(r.begin(), r.end(), comp); // Put it into priority-queue order: reverse(r.begin(), r.end()); return r; } }; int main() { PQV > pqi; srand(time(0)); for(int i = 0; i < 100; i++) pqi.push(rand() % 25); const vector& v = pqi.getVector(); copy(v.begin(), v.end(), ostream_iterator(cout, " ")); cout << "\n-----------" << endl; while(!pqi.empty()) { cout << pqi.top() << ' '; pqi.pop(); } } ///:~