日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

c++ STL:队列queue、优先队列priority queue 的使用

發布時間:2024/4/14 c/c++ 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c++ STL:队列queue、优先队列priority queue 的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

說明:本文全文轉載而來,原文鏈接:http://www.cppblog.com/wanghaiguang/archive/2012/06/05/177644.html

C++ Queues(隊列)

C++隊列是一種容器適配器,它給予程序員一種先進先出(FIFO)的數據結構。
1.back() 返回一個引用,指向最后一個元素
2.empty() 如果隊列空則返回真
3.front() 返回第一個元素
4.pop() 刪除第一個元素
5.push() 在末尾加入一個元素
6.size() 返回隊列中元素的個數

隊列可以用線性表(list)或雙向隊列(deque)來實現(注意vector container 不能用來實現queue,因為vector 沒有成員函數pop_front!):
queue<list<int>> q1;
queue<deque<int>> q2;
其成員函數有“判空(empty)” 、“尺寸(Size)” 、“首元(front)” 、“尾元(backt)” 、“加入隊列(push)” 、“彈出隊列(pop)”等操作。

例:

1 int main() 2 { 3 queue<int> q; 4 q.push(4); 5 q.push(5); 6 printf("%d\n",q.front()); 7 q.pop(); 8 }

?

C++ Priority Queues(優先隊列)

C++優先隊列類似隊列,但是在這個數據結構中的元素按照一定的斷言排列有序。
1.empty() 如果優先隊列為空,則返回真
2.pop() 刪除第一個元素
3.push() 加入一個元素
4.size() 返回優先隊列中擁有的元素的個數
5.top() 返回優先隊列中有最高優先級的元素

優先級隊列可以用向量(vector)或雙向隊列(deque)來實現(注意list container 不能用來實現queue,因為list 的迭代器不是任意存取iterator,而pop 中用到堆排序時是要求randomaccess iterator 的!):
priority_queue<vector<int>, less<int>> pq1; // 使用遞增less<int>函數對象排序
priority_queue<deque<int>, greater<int>> pq2; // 使用遞減greater<int>函數對象排序
其成員函數有“判空(empty)” 、“尺寸(Size)” 、“棧頂元素(top)” 、“壓棧(push)” 、“彈棧(pop)”等。

例:

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

?

????? 輸出結果為(注意是按照z的順序從大到小出隊的):?
????? 3 3 6?
????? 2 2 5?
????? 1 5 4?
????? 4 4 3

????? 再看一個按照z的順序從小到大出隊的例子:

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

?

????? 輸出結果為:?
????? 4 4 3?
????? 1 5 4?
????? 2 2 5?
????? 3 3 6
????? 如果我們把第一個例子中的比較運算符重載為: bool operator < (const T &t1, const T &t2) { return t1.z > t2.z; // 按照z的順序來決定t1和t2的順序} 則第一個例子的程序會得到和第二個例子的程序相同的輸出結果。

轉載于:https://www.cnblogs.com/zhoutaotao/p/3810894.html

總結

以上是生活随笔為你收集整理的c++ STL:队列queue、优先队列priority queue 的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: v天堂中文在线 | 欧美xxxx黑人xyx性爽 | 亚洲黄业 | 一级片一级片 | 少妇精品无码一区二区免费视频 | 96久久精品 | 欧美性精品 | 天天干夜夜拍 | 沟厕沟厕近拍高清视频 | 波多野结衣视频网站 | 午夜一区二区视频 | 日韩精品999| 成人av在线播放网站 | 国产青草视频 | 国内偷拍一区 | 中文字幕在线日本 | 超碰在线色 | 夜色一区二区三区 | 漂亮人妻被黑人久久精品 | 你懂的在线视频网站 | a√在线观看 | 国产jzjzjz丝袜老师水多 | 国产又色又爽无遮挡免费动态图 | 男女午夜爽爽爽 | 真实的国产乱xxxx在线91 | 91av视频在线观看 | 日韩在线观看免费 | 老狼影院伦理片 | 欧美成人一区二区 | 上原亚衣在线观看 | 人操人操 | 艳母日本动漫在线观看 | 奇米四色7777 | 中文不卡在线 | 放荡的美妇在线播放 | 黄色av中文字幕 | 亚洲午夜av久久乱码 | 九草视频在线观看 | 成人av中文解说水果派 | 鲁啊鲁在线视频 | 亚洲色图制服诱惑 | 国产色图片 | 亚洲精品在线观看视频 | 日本伦理片在线播放 | 亚洲一区二区三区四 | av在线免 | 国产九九精品视频 | 夜夜春av| 日韩女同强女同hd | 中文字幕 成人 | 福利视频一二区 | 国产高潮白浆 | 手机av不卡 | 性猛交富婆╳xxx乱大交麻豆 | 俄罗斯厕所偷拍 | 日韩欧美精品一区二区三区 | 午夜插插插| 国产11页 | 国产www性| 久久99久久99 | 久久99精品久久只有精品 | 亚洲精品伊人 | 九九在线免费视频 | 瑟瑟综合| 亚洲一级无毛 | 好吊色一区二区 | 日韩精品视频一区二区在线观看 | 少妇精品无码一区二区三区 | 欧美高清免费 | 亚洲乱妇 | 日韩午夜免费视频 | 朴银狐电影中文在线看 | 毛片在线免费观看视频 | 欧美网站在线 | 亚洲精品国产精华液 | 最新日韩精品 | 91老师片黄在线观看 | 青青草原伊人网 | 久久久久亚洲av成人网人人软件 | 色涩久久| 午夜h | 黄色h视频 | av色图片| 毛片免费全部无码播放 | 少妇名器的沉沦 | 68日本xxxxxⅹxxx22 | 阿v免费在线观看 | 波多野结衣视频观看 | 国产精品有限公司 | 九九视频在线 | 日本白嫩的bbw | 69视频一区二区 | 欧美一区成人 | 国产日产精品一区 | se在线观看 | 亚洲天天av| 视频一区二区三区在线 | 久久久国产精品久久久 | 美女狠狠干 |