原文链接:http://blog.csdn.net/coder_xia/article/details/6627902
如堆一样,队列也有2种,最大优先级队列和最小优先级队列。最大优先级队列的一个应用是在一台分时计算机上进行作业调度(终于搞到点有用的),对于最大优先级队列,支持以下操作:
1)INSERT(S,x)把元素x插入队列S
2)MAXIMUM(S):返回S中最大元素
3)EXTRACT-MAX(S):去掉并返回S中最大元素
4)INCRESE-KEY(S,x,key)在x位置插入值key。
优先级队列,用堆实现,这就是看到的必杀运用了。
我们以82页图为例
示范程序如下:
- //============================================================================
- // Name : prioity.cpp
- // Author : xia
- // Version : 1.0
- // Copyright : NUAA
- // Description : 优先级队列的模拟实现
- //============================================================================
- #include <iostream>
- #include <climits> //INT_MIN
- #include <vector> //vector
- #include <algorithm>//for_each
- using namespace std;
- int Parent(int i)
- {//返回i节点的父节点
- if (i>0)
- return i/2;
- return -1;
- }
- void MaxHeapify(vector<int> &v ,int i ,int heap_size)
- {//让A[i]在最大堆中下降,使以i为根的子树成为大顶堆
- int left=2*i; //l<-LEFT(i)
- int right = 2*i+1; //r<-RIGHT(i)
- int largest=i;
- if ( (left <= heap_size) && (v[left] > v[i]) )
- largest = left ;
- else
- largest = i;
- if ( (right <=heap_size ) && (v[right] > v[largest]) )
- largest = right;//从父母和自己中找出最大的
- if (largest != i)
- {
- swap(v[i],v[largest]);//交换使i和子堆满足堆性质,不过largest为根的可能违反,递归调整
- MaxHeapify(v,largest, heap_size);
- }
- }
- void BuildHeap(vector<int> &v)
- {//建堆
- for (int i=v.size()/2 ; i > 0 ; i--)
- MaxHeapify(v,i,v.size()-1);
- }
- int HeapMaximum(vector<int> A)
- { //返回堆上的最大元素
- return A[1];
- }
- int HeapExtractMax(vector<int> &A )
- { //去掉并返回A中最大的值
- int heap_size = A.size()-1;
- if ( heap_size <1 )
- {
- cout << " heap underflow" << endl;
- exit(EXIT_FAILURE);
- }
- int max = A[1];
- A[1] = A[heap_size];
- heap_size--;
- A.pop_back();
- MaxHeapify(A,1 ,heap_size);
- return max;
- }
- void HeapIncreaseKey(vector<int> &A , int i, int key)
- { //在i处插入值为key的数,并调整堆
- if (key<A[i])
- {
- cout << " new key is smaller than current key " << endl;
- exit(EXIT_FAILURE);
- }
- A[i] = key;
- while ( (i>1) && (A[Parent(i)] < A[i]))
- {
- swap(A[i],A[Parent(i)]);
- i = Parent(i) ;
- }
- }
- void MaxHeapInsert(vector<int> &A , int key)
- {
- A.push_back(INT_MIN); //伪代码heapsize+1,且插入负无穷
- HeapIncreaseKey(A,A.size()-1,key);//第二个参数实际为堆大小
- }
- template <class T>
- class Print
- {
- public:
- void operator () (T& t)
- {
- cout << t << " ";
- }
- };
- const int heap_size = 10; //这里假设元素为10个
- int main()
- {
- int temp[heap_size]={16,14,10,8,7,9,3,2,4,1};
- vector<int> v(temp+0,temp+heap_size);
- Print<int> print;
- v.insert(v.begin(),0);//插入个0,切合伪代码
- BuildHeap(v); //虽然我们的数组顺序已经符合堆,不过常理还是要先建堆
- cout << "初始堆V " << endl;
- for_each(v.begin()+1,v.end(),print);//遍历输出
- cout << endl<< endl;
- cout <<"插入个试试 " << endl;
- HeapIncreaseKey(v,9,15);//p82图
- for_each(v.begin()+1,v.end(),print);