C++queue容器學習(詳解)


一.queue模版類的定義在<queue>頭文件中。

queue與stack模版非常類似,queue模版也需要定義兩個模版參數,一個是元素類型,一個是容器類型,元素類型是必要的,容器類型是可選的,默認為dqueue類型。

定義queue對象的示例代碼如下:

queue<int>q1;

queue<double>q2;

queue的基本操作有:

1.入隊:如q.push(x):將x元素接到隊列的末端;

2.出隊:如q.pop() 彈出隊列的第一個元素,並不會返回元素的值;

3,訪問隊首元素:如q.front()

4,訪問隊尾元素,如q.back();

5,訪問隊中的元素個數,如q.size();

二.優先隊列

在<queue>頭文件中,還定義了一個非常有用的模版類priority_queue(優先隊列),優先隊列與隊列的差別在於優先隊列不是按照入隊的順序出隊,而是按照隊列中元素的優先權順序出隊(默認為大者優先,也可以通過指定算子來指定自己的優先順序)。

priority_queue模版類有三個模版參數,元素類型,容器類型,比較算子。其中后兩個都可以省略,默認容器為vector,默認算子為less,即小的往前排,大的往后排(出隊時序列尾的元素出隊)。

定義priority_queue對象的示例代碼如下:

priority_queue<int >q1;

priority_queue<pair<int,int> >q2;

priority_queue<int,vector<int>,greater<int> >q3;//定義小的先出隊

priority_queue的基本操作均與queue相同

初學者在使用priority_queue時,最困難的可能就是如何定義比較算子了。如果是基本數據類型,或已定義了比較運算符的類,可以直接用STL的less算子和greater算子——默認為使用less算子,即小的往前排,大的先出隊。如果要定義自己的比較算子,方法有多種,這里介紹其中的一種:重載比較運算符。優先隊列試圖將兩個元素x和y代入比較運算符(對less算子,調用x<y,對greater算子,調用x>y),若結果為真,則x排在y前面,y將先於x出隊,反之,則將y排在x前面,x將先出隊。

看下面這個簡單的示例:

 1 #include<iostream>
 2 #include<queue>
 3 #include<stdlib.h>
 4 using namespace std;
 5 class T
 6 {
 7 public:
 8     int x,y,z;
 9     T(int a,int b,int c):x(a),y(b),z(c)
10     {
11     }
12 };
13 bool operator<(const T&t1,const T&t2)
14 {
15     return t1.z<t2.z;
16 }
17 int main(void)
18 {
19     priority_queue<T>q;
20     q.push(T(4,4,3));
21     q.push(T(2,2,5));
22     q.push(T(1,5,4));
23     q.push(T(3,3,6));
24     while(!q.empty())
25     {
26         T t=q.top();
27         q.pop();
28         cout<<t.x<<" "<<t.y<<" "<<t.z<<endl;
29     }
30     system("Pause");
31     return 1;
32 }

輸出結果為

注意這里是按照z的順序從大到小出隊的。

如果我們把上述例子中的比較運算符重載改為:

bool operator<(const T &t1,const T &t2)

{

return t1.z>t2.z;

}

那么得到的輸出結果將會按照z的順序從小到大出隊。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM